3 回答

TA貢獻(xiàn)1842條經(jīng)驗(yàn) 獲得超13個(gè)贊
如果您想對(duì)數(shù)據(jù)建模,并且在決定這樣做之前來(lái)這里檢查mongodb是否可以對(duì)多個(gè)字段執(zhí)行聯(lián)接,請(qǐng)繼續(xù)閱讀。
盡管MongoDB可以執(zhí)行聯(lián)接,但是您也可以根據(jù)應(yīng)用程序訪問(wèn)模式自由地對(duì)數(shù)據(jù)建模。如果數(shù)據(jù)與問(wèn)題中顯示的一樣簡(jiǎn)單,我們可以簡(jiǎn)單地維護(hù)一個(gè)如下所示的單個(gè)集合:
{
user1: 1,
user2: 2,
percent1: 0.56,
percent2: 0.3
}
現(xiàn)在,您可以對(duì)本集合執(zhí)行所有操作,而這些操作本來(lái)可以加入的。我們?yōu)槭裁匆苊饧尤耄坑捎诜制希╠ocs)不支持它們,這將阻止您在需要時(shí)進(jìn)行橫向擴(kuò)展。規(guī)范化數(shù)據(jù)(具有單獨(dú)的表/集合)在SQL中效果很好,但是在Mongo中,避免聯(lián)接可以帶來(lái)很多好處,而在大多數(shù)情況下不會(huì)產(chǎn)生任何后果。僅當(dāng)您別無(wú)選擇時(shí),才在MongoDB中使用規(guī)范化。從文檔:
通常,使用規(guī)范化的數(shù)據(jù)模型:
嵌入時(shí)將導(dǎo)致數(shù)據(jù)重復(fù),但無(wú)法提供足夠的讀取性能優(yōu)勢(shì),無(wú)法勝過(guò)重復(fù)的影響。
代表更復(fù)雜的多對(duì)多關(guān)系。
為大型分層數(shù)據(jù)集建模。
檢查此處以了解有關(guān)嵌入的更多信息以及為什么要選擇它而不是標(biāo)準(zhǔn)化。

TA貢獻(xiàn)1798條經(jīng)驗(yàn) 獲得超3個(gè)贊
您可以使用$ match和$ project管道進(jìn)行多個(gè)字段匹配。(請(qǐng)參閱此處的詳細(xì)答案-mongoDB在多個(gè)字段上聯(lián)接)
db.collection1.aggregate([
{"$lookup": {
"from": "collection2",
"localField": "user1",
"foreignField": "user1",
"as": "c2"
}},
{"$unwind": "$c2"},
{"$project": {
"user2Eq": {"$eq": ["$user2", "$c2.user2"]},
"user1": 1, "user2": 1,
"percent1": "$percent", "percent2": "$c2.percent"
}},
{"$match": {
{"user2Eq": {"$eq": True}}
}},
{"$project": {
"user2Eq": 0
}}
])
- 3 回答
- 0 關(guān)注
- 1536 瀏覽
添加回答
舉報(bào)