'MongoNotConnectedError' - 我试图将 post 数据发送到 mongodb 并且发生了这个错误
'MongoNotConnectedError' - I was trying to post data to mongodb and this error occured
当我控制台记录 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-ema-john-server\node_modules\mongodb\lib\utils.js:389:11)
at Collection.insertMany (F:\Node-js-ema-john-server\node_modules\mongodb\lib\collection.js:157:61)
at F:\Node-js-ema-john-server\index.js:26:24
at Layer.handle [as handle_request] (F:\Node-js-ema-john-server\node_modules\express\lib\router\layer.js:95:5)
at next (F:\Node-js-ema-john-server\node_modules\express\lib\router\route.js:137:13)
at Route.dispatch (F:\Node-js-ema-john-server\node_modules\express\lib\router\route.js:112:3)
at Layer.handle [as handle_request] (F:\Node-js-ema-john-server\node_modules\express\lib\router\layer.js:95:5)
at F:\Node-js-ema-john-server\node_modules\express\lib\router\index.js:281:22
at Function.process_params (F:\Node-js-ema-john-server\node_modules\express\lib\router\index.js:335:12)
at next (F:\Node-js-ema-john-server\node_modules\express\lib\router\index.js:275:10)
你能试试下面的代码片段并让我知道输出结果吗:
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);
client.close();
res.send(result.insertedCount);
});
});
});
我得到了答案:)
只需删除 client.close()
当我控制台记录 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-ema-john-server\node_modules\mongodb\lib\utils.js:389:11)
at Collection.insertMany (F:\Node-js-ema-john-server\node_modules\mongodb\lib\collection.js:157:61)
at F:\Node-js-ema-john-server\index.js:26:24
at Layer.handle [as handle_request] (F:\Node-js-ema-john-server\node_modules\express\lib\router\layer.js:95:5)
at next (F:\Node-js-ema-john-server\node_modules\express\lib\router\route.js:137:13)
at Route.dispatch (F:\Node-js-ema-john-server\node_modules\express\lib\router\route.js:112:3)
at Layer.handle [as handle_request] (F:\Node-js-ema-john-server\node_modules\express\lib\router\layer.js:95:5)
at F:\Node-js-ema-john-server\node_modules\express\lib\router\index.js:281:22
at Function.process_params (F:\Node-js-ema-john-server\node_modules\express\lib\router\index.js:335:12)
at next (F:\Node-js-ema-john-server\node_modules\express\lib\router\index.js:275:10)
你能试试下面的代码片段并让我知道输出结果吗:
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);
client.close();
res.send(result.insertedCount);
});
});
});
我得到了答案:)
只需删除 client.close()