摘要:源地址同庫(kù)聯(lián)表查詢這里只對(duì)同庫(kù)聯(lián)表查詢做介紹,跨庫(kù)聯(lián)表查詢可能在之后也會(huì)介紹因?yàn)楣炯軜?gòu)變動(dòng),之后可能會(huì)聯(lián)表查詢我用到的聯(lián)表查詢有兩種,一種是的,一種是是使用外鍵關(guān)聯(lián)子表例如現(xiàn)在有一張訂單表結(jié)構(gòu)動(dòng)態(tài)外鍵用戶訂單類型訂單的狀態(tài)完成未完成失效用
源地址:mongo同庫(kù)聯(lián)表查詢
這里只對(duì)同庫(kù)聯(lián)表查詢做介紹,跨庫(kù)聯(lián)表查詢可能在之后也會(huì)介紹(因?yàn)楣炯軜?gòu)變動(dòng),之后可能會(huì)聯(lián)表查詢)
我用到的聯(lián)表查詢有兩種,一種是mongoose的populate,一種是$lookup
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ì)說了
$lookuplookup就是使用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),沒試過)
參考文章
Mongoose中的關(guān)聯(lián)表查詢 && 聚合查詢
在mongoose中填充外鍵
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/19057.html
摘要:本文會(huì)選擇三個(gè)場(chǎng)景,給大家簡(jiǎn)單介紹一下在摩拜單車的使用姿勢(shì)遇到的問題以及解決方案。圖在線業(yè)務(wù)集群拓?fù)鋱D四數(shù)據(jù)沙盒集群離線業(yè)務(wù)數(shù)據(jù)沙盒,屬于離線業(yè)務(wù)集群,是摩拜單車的一個(gè)數(shù)據(jù)聚合集群。 作者介紹:呂磊,摩拜單車高級(jí) DBA。 一、業(yè)務(wù)場(chǎng)景 摩拜單車 2017 年開始將 TiDB 嘗試應(yīng)用到實(shí)際業(yè)務(wù)當(dāng)中,根據(jù)業(yè)務(wù)的不斷發(fā)展,TiDB 版本快速迭代,我們將 TiDB 在摩拜單車的使用場(chǎng)景逐漸...
摘要:原文鏈接為什么選擇了我也不知道官方中文論壇官方文檔中文文檔安裝此處的方式是安裝部署不用考慮環(huán)境配置問題,但是相應(yīng)的也會(huì)有一些弊端比如文件的修改等變得麻煩下方為鏡像的為了修改文件方便,加了一個(gè)文件夾方便和宿主機(jī)文件交換同步上傳的 原文鏈接 為什么選擇了NodeBB?我也不知道~~~ NodeBB官方Github NodeBB中文論壇 NodeBB官方文檔 NodeBB中文文檔 安裝 此...
摘要:有挫敗感,故現(xiàn)在把聯(lián)表的拆分寫一篇文章。在最開始,先解釋一年的聯(lián)表查詢的機(jī)制。現(xiàn)在又三張表基礎(chǔ)信息擴(kuò)展信息銀行存款現(xiàn)在需要取出每個(gè)會(huì)員的基本信息,擴(kuò)展信息以及銀行存款。最好的辦法就是對(duì)這個(gè)進(jìn)行拆分。 今天有朋友問了我一個(gè)問題,說: 有四張表,他要從四張表里面取數(shù)據(jù),他已經(jīng)設(shè)計(jì)好了數(shù)據(jù)冗余等等,但還是需要通過聯(lián)表查詢來獲取數(shù)據(jù),問我有沒有比較好的解決辦法。說了挺長(zhǎng)時(shí)間,朋友沒聽明白。有...
閱讀 2011·2023-04-25 16:53
閱讀 1455·2021-10-13 09:39
閱讀 619·2021-09-08 09:35
閱讀 1652·2019-08-30 13:03
閱讀 2133·2019-08-30 11:06
閱讀 1842·2019-08-30 10:59
閱讀 3199·2019-08-29 17:00
閱讀 2300·2019-08-23 17:55