MongoDB 多对多关系的简单示例

时间:2022-05-06
本文章向大家介绍MongoDB 多对多关系的简单示例,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

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

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

Article:
    Id
    Title
    ...
Tag:
    Id
    Name
Relation:
    ArticleId
    TagId

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

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

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

设计示例

下面给出一个简单的思路

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

article
{
    id:"505cad",
    title:"test title",
    tags:["tag1","tag2"]
    ...
}
tag 
{
    tag:""
    article:["article1","article2"]
    size:2
}

查询示例

(1)列出所有Tag

db.article.distinct("tags")

返回数据例如:

[ "tag1", "tag2", "tag3" ]

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

db.article.find({});

返回数据例如:

{ 
"_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"]}});

返回数据例如:

{ 
"_id" : ObjectId("5058878"), 
"title" : "test title", 
"tags" : [ "tag1", "tag2" ] 
}