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

首頁 > 數據庫 > MongoDB > 正文

mongodb實現同庫聯表查詢方法示例

2020-10-29 18:45:38
字體:
來源:轉載
供稿:網友

前言

最近在工作中遇到一個問題,需要對mongodb數據庫進行聯表查詢操作,發現網上這方面的資料較少,無奈只能自己來實現了,下面話不多說了,來一起看看詳細的介紹:

注意:這里只對同庫聯表查詢做介紹,跨庫聯表查詢可能在之后也會介紹(因為公司架構變動,之后可能會聯表查詢)

我用到的聯表查詢有兩種,一種是mongoose的populate,一種是$lookup

一、populate

populate是使用外鍵關聯子表

例如現在有一張訂單表結構(動態外鍵):

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 }, // 訂單的狀態:1完成 2未完成 3失效})

用戶表:

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

現在我想根據查詢order表,并返回對應用戶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, // 訂單的狀態:1完成 2未完成 3失效 // }});

這里order表的uid指向了user表的_id字段,當然也可以在新建表的時候定義外鍵,這里就不細說了

二、$lookup

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

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字段,但值得注意的是兩個字段的類型必須一樣(3.5以上貌似可以轉,沒試過)

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

參考文章

Mongoose中的關聯表查詢 && 聚合查詢

在mongoose中填充外鍵

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产三级a三级三级 | 海外中文字幕在线观看 | 欧美一区二区黄色 | 一级做a在线观看 | 日本成人高清视频 | 91伊人久久 | 成人情欲视频在线看免费 | 在线观看免费视频麻豆 | 精品国产一区二区三区成人影院 | av在线免费观看中文字幕 | 久久影院yy6080 | 欧美黄色一级片在线观看 | av电影免费在线看 | 斗罗破苍穹在线观看免费完整观看 | 色网在线视频 | 国产一级毛片高清视频完整版 | 国产亚洲精品久久久久5区 男人天堂免费 | 激情久久婷婷 | 欧美aaaaa一级毛片在线 | 777午夜精品视频在线播放 | 一级黄色在线观看 | 久久毛片 | 一区二区网 | 日韩欧美电影一区二区三区 | 久久久久亚洲视频 | 性生活视频软件 | 久久中文一区 | 亚洲午夜久久久久 | 国产一区二区精品在线观看 | 热99在线视频 | 国产伦久视频免费观看视频 | 精品午夜影院 | 日韩精品中文字幕一区二区三区 | 国产成人高潮免费观看精品 | 国产一区二区三区四区五区精品 | 久久影院yy6080 | 噜噜噜躁狠狠躁狠狠精品视频 | 免费观看一级 | 欧美成人精品不卡视频在线观看 | 无遮挡一级毛片视频 | 嫩呦国产一区二区三区av |