node.js - 'MongoNotConnectedError' - 我试图将数据发布到 mongodb 并且发生了这个错误
问题描述
当我控制台记录 const products 变量时,我得到了产品,但我无法将数据插入 mongodb 数据库,并且它说 mongoClient 未连接。
const express = require("express");
const cors = require("cors");
const { MongoClient } = require("mongodb");
require("dotenv").config();
const app = express();
app.use(cors());
app.use(express.urlencoded({ extended: true }));
app.use(express.json());
const uri = `mongodb+srv://${process.env.DB_USER}:${process.env.DB_PASSWORD}@cluster0.lgrhg.mongodb.net/${process.env.DB_NAME}?retryWrites=true&w=majority`;
const client = new MongoClient(uri, {
useNewUrlParser: true,
useUnifiedTopology: true,
});
client.connect((err) => {
const productsCollection = client
.db(`${process.env.DB_NAME}`)
.collection(`${process.env.DB_COLLECTION}`);
console.log("database connected")
app.post("/addProduct", (req, res) => {
const products = req.body;
productsCollection.insertMany(products).then((result) => {
console.log(result.insertedCount);
res.send(result.insertedCount);
});
});
client.close();
});
app.listen(4000);
之后,我在控制台中得到了这个:
database connected
MongoNotConnectedError: MongoClient must be connected to perform this operation
at Object.getTopology (F:\Node-js\2-ema-john-server\node_modules\mongodb\lib\utils.js:389:11)
at Collection.insertMany (F:\Node-js\2-ema-john-server\node_modules\mongodb\lib\collection.js:157:61)
at F:\Node-js\2-ema-john-server\index.js:26:24
at Layer.handle [as handle_request] (F:\Node-js\2-ema-john-server\node_modules\express\lib\router\layer.js:95:5)
at next (F:\Node-js\2-ema-john-server\node_modules\express\lib\router\route.js:137:13)
at Route.dispatch (F:\Node-js\2-ema-john-server\node_modules\express\lib\router\route.js:112:3)
at Layer.handle [as handle_request] (F:\Node-js\2-ema-john-server\node_modules\express\lib\router\layer.js:95:5)
at F:\Node-js\2-ema-john-server\node_modules\express\lib\router\index.js:281:22
at Function.process_params (F:\Node-js\2-ema-john-server\node_modules\express\lib\router\index.js:335:12)
at next (F:\Node-js\2-ema-john-server\node_modules\express\lib\router\index.js:275:10)
解决方案
我得到了答案:)
只需删除 client.close()
推荐阅读
- c - C程序写入目录的内容
- django - 我可以从单个 Django 函数中分别返回模板和变量吗?
- azure - 使用 Redisson 和 Azure Redis 缓存遇到 RedisTimeoutException 和其他异常
- docker - 如何将 CA 根证书添加到 Jenkins Docker 容器上的 LDAP 密钥库?
- javascript - 向赛普拉斯配置添加第三方 cookie 例外
- xml - Azure 部署:错误 MSB4041:项目的默认 XML 命名空间必须是 MSBuild XML 命名空间
- python - 将计数器列表转换为稀疏 Pandas DataFrame
- excel - 粘贴在 Excel 中转置的形状
- java - 我的 if 语句是否会影响我的菜单?
- google-apps-script - 使用谷歌应用程序脚本将谷歌表格上的列增加 1?