[英]Mongoose always returns an empty array in NodeJS
我正在嘗試在 MongoDB Atlas 上提取products
集合的所有products
。 我得到的只是空數組。
我有一個正確的數據庫連接。
我不確定該模型以及我如何使用 Mongoose。
這是我的連接... connectDb.js
import mongoose from "mongoose";
const connection = {};
async function connectDb() {
if (connection.isConnected) {
console.log("Connection in progress");
return;
}
const db = await mongoose.connect(process.env.MONGO_SRV, {
useCreateIndex: true,
useFindAndModify: false,
useNewUrlParser: true,
useUnifiedTopology: true,
});
console.log("DB Connected");
connection.isConnected = db.connections[0].readyState;
}
export default connectDb;
這是我的架構... ./models/Product.js
import mongoose from "mongoose";
import shortid from "shortid";
const { String, Number } = mongoose.Schema.Types;
const ProductSchema = new mongoose.Schema({
name: {
type: String,
required: true,
},
price: {
type: Number,
required: true,
},
description: {
type: String,
required: true,
},
sku: {
type: String,
unique: true,
required: true,
default: shortid.generate(),
},
mediaUrl: {
type: String,
required: true,
},
});
// Check for an existing `models.Product` ... then run the product schema
export default mongoose.models.Product ||
mongoose.model("products", ProductSchema);
這是我的查詢... ./api/products.js
import Product from "../../models/Product";
import connectDb from "../../utils/connectDb";
connectDb();
export default async (req, res) => {
const products = await Product.find({});
console.log(`products are ... ${products}`);
res.status(200).json(products);
};
這是我的數據庫
這是控制台中的結果......
根據貓鼬文檔,如果db.connections[0].readyState}
返回 1...這意味着已連接的連接文檔
檢查您的env
VAR MONGO_SRV
。 確保您的連接 URL 與相關數據庫。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.