前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MongoDB 多对多关系的简单示例

MongoDB 多对多关系的简单示例

作者头像
dys
发布2018-04-02 17:29:15
3.2K0
发布2018-04-02 17:29:15
举报
文章被收录于专栏:性能与架构性能与架构

例如文章的标签,一篇文章可能包含多个标签,一个标签也会对应多篇文章

这是一个多对多的映射关系,在sql中我们一般这样设计

代码语言:javascript
复制
Article:
    Id
    Title
    ...
Tag:
    Id
    Name
Relation:
    ArticleId
    TagId

通过表的连接,就可以查询出我们想要的各种数据

那么,如果用MongoDB的思想,该如何设计这种关系呢?

有一个关键点首先要知道:MongoDB中不支持文档的连接操作,所以就不能按照sql的思路来设计

设计示例

下面给出一个简单的思路

设计两个文档,文章 和 标签,每次文章添加新标签的时候,更新文章和标签的对应关系

代码语言:javascript
复制
article
{
    id:"505cad",
    title:"test title",
    tags:["tag1","tag2"]
    ...
}
tag 
{
    tag:""
    article:["article1","article2"]
    size:2
}

查询示例

(1)列出所有Tag

代码语言:javascript
复制
db.article.distinct("tags")

返回数据例如:

代码语言:javascript
复制
[ "tag1", "tag2", "tag3" ]

(2)列出所有文章及其Tag

db.article.find({});

返回数据例如:

代码语言:javascript
复制
{ 
"_id" : ObjectId("5058878"), 
"title" : "test title", 
"tags" : [ "tag1", "tag2" ] 
}
{ "_id" : ObjectId("505879"), 
"title" : "test title2", 
"tags" : [ "tag1", "tag3" ] 
}

(3)列出某Tag下的所有文章

db.article.find({tags:{$in:["tag2"]}});

返回数据例如:

代码语言:javascript
复制
{ 
"_id" : ObjectId("5058878"), 
"title" : "test title", 
"tags" : [ "tag1", "tag2" ] 
}
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2015-10-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 JAVA高性能架构 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 MongoDB
腾讯云数据库 MongoDB(TencentDB for MongoDB)是腾讯云基于全球广受欢迎的 MongoDB 打造的高性能 NoSQL 数据库,100%完全兼容 MongoDB 协议,支持跨文档事务,提供稳定丰富的监控管理,弹性可扩展、自动容灾,适用于文档型数据库场景,您无需自建灾备体系及控制管理系统。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档