首页 > 解决方案 > '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)

标签: node.jsmongodbmongodb-atlas

解决方案


我得到了答案:)

只需删除 client.close()


推荐阅读