前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用Mongoose做关联查询的设计方案

使用Mongoose做关联查询的设计方案

作者头像
飞奔去旅行
发布2019-06-13 14:11:12
2.7K1
发布2019-06-13 14:11:12
举报
文章被收录于专栏:智慧协同智慧协同

场景

一个系统可以注册多个用户,每个用户可以发表文章。

两个Schema:

  • User:用户
  • Article:文章

其中一个用户可以包含多个文章

使用mongoose

在关系型数据库中,我们通常将这两个对象设计成一对多的关系,一个User对应多个Article。而使用mongoose我们可以如此设计:

User:

代码语言:javascript
复制
{
    username: {type: String, required: true, unique: true},// 用户名
    password: {type: String, required: true}
}

Article:

代码语言:javascript
复制
{
    title: {type: String, required: true}, 
    content: {type: String, required: true}, 
    created_time: {type: Date, default: Date.now}, 
    _user: {
       type: Schema.Types.ObjectId,
       ref: 'User'
    }
}

Article中的_user字段是关键,使用ref,将其与User关联,那么使用mongoose查询Article时(populate方法),就会将其关联的User一并查出。

代码语言:javascript
复制
Article.findById('articleId').populate('_user').exec(function(err, doc){
    console.log(doc._user.username);
})

关键字: populate

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016.01.18 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 场景
  • 使用mongoose
相关产品与服务
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档