gpt4 book ai didi

node.js - 通过 db.collection.count() 检查 MongoDb 数据库是否为空 - 不起作用

转载 作者:行者123 更新时间:2023-12-02 04:09:31 25 4
gpt4 key购买 nike

我通过 Mongoose 连接到 MongoDb。然后,当连接成功时,我想检查数据库是否为空(意味着没有集合)。如果为空,我将向数据库播种数据。

我正在使用db.collection.count()来计算集合,但此代码不起作用。

var dbURI = 'mongodb://localhost/voddb';
mongoose.connect(dbURI);

mongoose.connection.on('connected', function () {
console.log('Mongoose default connection open to ' + dbURI);
if(mongoose.connection.db.collection.count() == 0) {
//seed database
}
});

它在 collection.count() 处向我抛出一个错误:

TypeError: Cannot read property 'collection' of undefined

出了什么问题?

最佳答案

您正在使用 mongoose.connection.db.collection 这是一个函数,您可以使用 mongoose.connection.db.collection('your_collection_name').count()

示例:

var dbURI = 'mongodb://localhost/my_db_name';

mongoose.connect(dbURI);

mongoose.connection.on('connected', function () {
console.log('Mongoose default connection open to ' + dbURI);

// To List all Collections of a Database
mongoose.connection.db.listCollections().toArray(function(err, names) {
if (err) {
console.log(err);
}
else {
names.forEach(function(e,i,a) {
console.log("----->", e.name);
});
}
});

// To Count Documents of a particular collection
mongoose.connection.db.collection('users').count(function(err, count) {
console.dir(err);
console.dir(count);

if( count == 0) {
console.log("No Found Records.");
}
else {
console.log("Found Records : " + count);
}
});
});

关于node.js - 通过 db.collection.count() 检查 MongoDb 数据库是否为空 - 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37459215/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com