![](/img/trans.png)
[英]How to retrieve documents stored in one to many relationship in Mongoose
[英]Mongoose Fails to retrieve documents
我现在正在学习MongoDB + Mongoose + Express。 我正面临一个我无法弄清自己的错误。
我的MongoDB设置(一个有2个集合的DB,每个集合都有一些文档):
app.js与数据库的连接:
const dbConnectionString = process.env.MONGODB_URI || 'mongodb://localhost';
mongoose.connect(dbConnectionString + '/blog');
posts.js模型:
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var PostsSchema = new Schema({
any: {}
});
var Posts = mongoose.model('Posts', PostsSchema);
module.exports = Posts;
blog.js路线:
var express = require('express');
var router = express.Router();
var Posts = require('../models/posts')
router.get('/', function(req, res, next) {
console.log('Route works');
console.log(Posts);
Posts.find((err,posts) => {
if( err ) return console.log('DB Error', err);
console.log('Posts Received', posts);
res.render('blog', { title: 'My Blog', posts : posts });
});
});
module.exports = router;
当我运行mongodb和节点服务器时,成功访问它console.logs架构和
Route works
Posts Received []
因此,尽管连接到数据库似乎正常(我没有收到错误),但我无法从中获取数据。 我知道由于缺乏知识而缺少明显的东西,但是我通过猫鼬文档进行搜索没有帮助。 请提出建议,并感谢您的帮助!
问题是您没有传递任何对象来查找。
猫鼬的查找功能需要查询参数。 如果需要检索整个集合,则可以传递一个空对象:
MongooseSchema.find({},callback)
第一个对象是查询。 您也可以在其中使用一些选择器。 例如,假设您希望每个人都拥有确定的标题,在这种情况下,您可以执行以下操作:
MongooseSchema.find({title:"title"},callback)
对于多个查询参数,可以用逗号分隔:
MongooseSchema.find({title:"title",subtitle:"subtitle"},callback)
等等。 我建议您在此问题上看一下猫鼬手册部分:
http://mongoosejs.com/docs/queries.html
[更新]
这种情况下的问题是猫鼬命名约定与您使用的名称不匹配。 猫鼬使用小写名称查询,在这种情况下,由于名称开头的大写字母P,因此找不到Posts集合。 通过用“小写”更改帖子来解决。
再次提醒一下,在创建集合时,猫鼬还会使名称多元化,因此在mongodb中创建集合时也应注意这一事实。
@veeram的参考: http ://mongoosejs.com/docs/guide.html#collection
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.