我设定了几个集合,Country
, Province
, City
, Univ
.
country和province,province和city,city和univ之间都是一对多的关系。通过引用连接。
现在我想知道,一个country中有哪些univ,这个要怎么做?假设该country为country0.
文档结构如下:
{
_id:"country0",
provinces:[
{
$ref:"Province",
$id:"province0"
},
...
]
}
{
_id:"province0",
belongs:{$ref:"Country", $id:"country0"},
cities:[
{
$ref:"City",
$id:"city0"
}
...
]
}
{
_id:"city0",
belongsTo:{$ref:"Province",$id:"province0"},
univs:[
{
$ref:"Univ",
$id:"univ0"
}
...
]
}
{
_id:"univ0",
address:{$ref:"City", $id:"city0"}
}
我找过一些资料,如果country只有一个,并且涉及到的引用不超过两层,可以用fetch()函数。但是这里至少有3层了。
也看到有人介绍引用的时候说可以用python驱动,但是用python驱动的话,就不好记录查询性能了。
我自己的思路是:
但是涉及到的命令太多了,显得繁琐
高洛峰2017-04-24 09:12:28
大学の市/県/国が変更される可能性はほとんどないため、正しい解決策は、これらのフィールドを大学の文書に追加してインデックスを付けることです。
{
_id:"univ0",
場所: { 都市: { }、県: {}、国: {} }
}
db.university.ensureIndex({"location.country":1});
DBRef を使用するか、都市/県/国の名前を直接保存するかを選択できます。