麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 數(shù)據(jù)庫(kù) > MongoDB > 正文

mongodb實(shí)現(xiàn)同庫(kù)聯(lián)表查詢方法示例

2020-03-14 12:53:26
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

最近在工作中遇到一個(gè)問(wèn)題,需要對(duì)mongodb數(shù)據(jù)庫(kù)進(jìn)行聯(lián)表查詢操作,發(fā)現(xiàn)網(wǎng)上這方面的資料較少,無(wú)奈只能自己來(lái)實(shí)現(xiàn)了,下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹:

注意:這里只對(duì)同庫(kù)聯(lián)表查詢做介紹,跨庫(kù)聯(lián)表查詢可能在之后也會(huì)介紹(因?yàn)楣炯軜?gòu)變動(dòng),之后可能會(huì)聯(lián)表查詢)

我用到的聯(lián)表查詢有兩種,一種是mongoose的populate,一種是$lookup

一、populate

populate是使用外鍵關(guān)聯(lián)子表

例如現(xiàn)在有一張訂單表結(jié)構(gòu)(動(dòng)態(tài)外鍵):

var orderSchema = new mongoose.Schema({ uid: { type: String, required: true }, // 用戶id amount: { type: Number, required: true }, oType: { type: Number, required: true }, // 訂單類型 status: { type: Number, required: true }, // 訂單的狀態(tài):1完成 2未完成 3失效})

用戶表:

var userSchema = new mongoose.Schema({ phone: String, status: String, createdAt: Date, updatedAt: Date})

現(xiàn)在我想根據(jù)查詢order表,并返回對(duì)應(yīng)用戶phone字段

order.find().populate({path: 'uid', model: User, select: '_id real_name phone bankcard'}).exec(function(err, order) { // order: { // uid: { // phone: '15626202254', // status: "expand", // createdAt: Date, // updatedAt: Date // }, // amount: 5000, // oType: 2, // 訂單類型 // status: 1, // 訂單的狀態(tài):1完成 2未完成 3失效 // }});

這里order表的uid指向了user表的_id字段,當(dāng)然也可以在新建表的時(shí)候定義外鍵,這里就不細(xì)說(shuō)了

二、$lookup

lookup就是使用aggregate的$lookup屬性,直接上官網(wǎng)例子非常好懂

orders表

{ "_id" : 1, "item" : "abc", "price" : 12, "quantity" : 2 }{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1 }{ "_id" : 3 }

inventory表

{ "_id" : 1, "sku" : "abc", description: "product 1", "instock" : 120 }{ "_id" : 2, "sku" : "def", description: "product 2", "instock" : 80 }{ "_id" : 3, "sku" : "ijk", description: "product 3", "instock" : 60 }{ "_id" : 4, "sku" : "jkl", description: "product 4", "instock" : 70 }{ "_id" : 5, "sku": null, description: "Incomplete" }{ "_id" : 6 }
db.orders.aggregate([ { $lookup: {  from: "inventory",  localField: "item",  foreignField: "sku",  as: "inventory_docs" } }])

就是使用order的item字段作為inventory表的查詢條件{sku: item},并賦值給inventory_docs字段,但值得注意的是兩個(gè)字段的類型必須一樣(3.5以上貌似可以轉(zhuǎn),沒(méi)試過(guò))

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)VEVB武林網(wǎng)的支持。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MongoDB頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 黄色片在线免费播放 | 成人免费一区二区 | 亚州欧美视频 | 久久精品九九 | 91色综合综合热五月激情 | 在线观看免费毛片视频 | 一区二区国产在线 | 男女牲高爱潮免费视频男女 | 中文字幕在线观看视频www | 国产高潮好爽受不了了夜色 | 成人在线视频免费观看 | 毛片在线免费观看网址 | 欧美国产精品一区二区 | 久久亚洲视频网 | 成人 日韩 | 懂色av懂色aⅴ精彩av | 日美av在线 | 久久久久久久久久久久久久av | 欧美四级在线观看 | 国产一有一级毛片视频 | 毛片免费视频观看 | 国产精品久久久久久久hd | 九草网| 在线成人免费视频 | 久久久久99精品 | 久久艹精品 | 久久久久久片 | 欧美性久久久 | 国产精品亚洲欧美一级在线 | 久久久久久久久久久av | 日韩字幕在线观看 | 黄色网址免费进入 | 99影视电影电视剧在线播放 | 麻豆一二区 | 一级电影在线观看 | wwwxxx国产 | 成人三级电影网站 | 成人不卡一区二区 | 最新av免费网址 | 91成人免费 | 欧美视频一级 |