MongoDB 的关系表示多个文档之间在逻辑上的相互联系。
文档间可以通过嵌入和引用来建立联系。
MongoDB 中的关系可以是:
接下来我们来考虑下用户与用户地址的关系。
一个用户可以有多个地址,所以是一对多的关系。
以下是 user 文档的简单结构:
{ "_id":ObjectId("52ffc33cd85242f436000001"), "name": "Tom Hanks", "contact": "987654321", "dob": "01-01-1991" }
以下是 address 文档的简单结构:
{ "_id":ObjectId("52ffc4a5d85242602e000000"), "building": "22 A, Indiana Apt", "pincode": 123456, "city": "Los Angeles", "state": "California" }
使用嵌入式方法,我们可以把用户地址嵌入到用户的文档中:
"_id":ObjectId("52ffc33cd85242f436000001"), "contact": "987654321", "dob": "01-01-1991", "name": "Tom Benzamin", "address": [ { "building": "22 A, Indiana Apt", "pincode": 123456, "city": "Los Angeles", "state": "California" }, { "building": "170 A, Acropolis Apt", "pincode": 456789, "city": "Chicago", "state": "Illinois" }] }
以上数据保存在单一的文档中,可以比较容易的获取很维护数据。 你可以这样查询用户的地址:
>db.users.findOne({"name":"Tom Benzamin"},{"address":1})
注意:以上查询中 db 和 users 表示数据库和集合。
这种数据结构的缺点是,如果用户和用户地址在不断增加,数据量不断变大,会影响读写性能。
引用式关系是设计数据库时经常用到的方法,这种方法把用户数据文档和用户地址数据文档分开,通过引用文档的 id 字段来建立关系。
{ "_id":ObjectId("52ffc33cd85242f436000001"), "contact": "987654321", "dob": "01-01-1991", "name": "Tom Benzamin", "address_ids": [ ObjectId("52ffc4a5d85242602e000000"), ObjectId("52ffc4a5d85242602e000001") ] }
以上实例中,用户文档的 address_ids 字段包含用户地址的对象id(ObjectId)数组。
我们可以读取这些用户地址的对象id(ObjectId)来获取用户的详细地址信息。
这种方法需要两次查询,第一次查询用户地址的对象id(ObjectId),第二次通过查询的id获取用户的详细地址信息。
>var result = db.users.findOne({"name":"Tom Benzamin"},{"address_ids":1}) >var addresses = db.address.find({"_id":{"$in":result["address_ids"]}})
查询是对数据结果的请求,也是对数据的操作。您可以使用查询来回答简单问题,执行计算,组合来自不同表的数据,或者甚至添加,更...
Redis Lpushx 命令Redis 列表(List)Redis Lpushx 将一个或多个值插入到已存在的列表头部,列表不存在时操作无效。语法 redis Lpu...
Redis Rpoplpush 命令Redis 列表(List)Redis Rpoplpush 命令用于移除列表的最后一个元素,并将该元素添加到另一个列表并返回。语...
Redis Pgmerge 命令 Redis HyperLogLog Redis Pgmerge 命令将多个 HyperLogLog 合并为一个 HyperLogLog ,合并后的 HyperLogLog ...
Redis Cluster Slots 命令 Redis 服务器 Redis Client Slots 命令用于当前的集群状态,以数组形式展示。语法 redis Client Slots...
Redis Eval 命令 Redis 脚本 Redis Eval 命令使用 Lua 解释器执行脚本。语法 redis Eval 命令基本语法如下:redis 127.0.0.1:637...
Redis Evalsha 命令 Redis 脚本 Redis Evalsha 命令根据给定的 sha1 校验码,执行缓存在服务器中的脚本。语法 redis Evalsha 命...
Redis Config Set 命令 Redis 服务器 Redis Config Set 命令可以动态地调整 Redis 服务器的配置(configuration)而无须重启。你可...