例如文章的标签,一篇文章可能包含多个标签,一个标签也会对应多篇文章
这是一个多对多的映射关系,在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" ]
}