婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > mongodb實(shí)現(xiàn)同庫聯(lián)表查詢方法示例

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

熱門標(biāo)簽:呼和浩特電銷外呼系統(tǒng)加盟 電銷機(jī)器人是什么軟件 蘋果汽車租賃店地圖標(biāo)注 怎么投訴地圖標(biāo)注 濟(jì)南電銷機(jī)器人加盟公司 杭州人工電銷機(jī)器人價(jià)格 云南外呼系統(tǒng) 廣州長安公司怎樣申請400電話 老虎洗衣店地圖標(biāo)注

前言

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

注意:這里只對同庫聯(lián)表查詢做介紹,跨庫聯(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表,并返回對應(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ì)說了

二、$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),沒試過)

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

參考文章

Mongoose中的關(guān)聯(lián)表查詢 聚合查詢

在mongoose中填充外鍵

您可能感興趣的文章:
  • MongoDB中多表關(guān)聯(lián)查詢($lookup)的深入講解
  • Mongodb實(shí)現(xiàn)的關(guān)聯(lián)表查詢功能【population方法】
  • MongoDB各種查詢操作詳解
  • MongoDB查詢操作限制返回字段的方法
  • PHP中MongoDB數(shù)據(jù)庫的連接、添加、修改、查詢、刪除等操作實(shí)例
  • MongoDB下根據(jù)數(shù)組大小進(jìn)行查詢的方法
  • MongoDB導(dǎo)出查詢結(jié)果到文件例子
  • MongoDB如何對數(shù)組中的元素進(jìn)行查詢詳解
  • MongoDB查詢技巧總結(jié)
  • MongoDB查詢性能優(yōu)化驗(yàn)證及驗(yàn)證
  • MongoDB的基礎(chǔ)查詢和索引操作方法總結(jié)
  • MongoDB多表關(guān)聯(lián)查詢操作實(shí)例詳解

標(biāo)簽:無錫 自貢 雞西 玉林 遼陽 興安盟 廈門 泰安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《mongodb實(shí)現(xiàn)同庫聯(lián)表查詢方法示例》,本文關(guān)鍵詞  mongodb,實(shí)現(xiàn),同庫,聯(lián)表,查詢,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《mongodb實(shí)現(xiàn)同庫聯(lián)表查詢方法示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于mongodb實(shí)現(xiàn)同庫聯(lián)表查詢方法示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 东台市| 晋宁县| 财经| 淮滨县| 平舆县| 余姚市| 巴中市| 屏东县| 韩城市| 安乡县| 绍兴市| 达日县| 五常市| 阿城市| 崇州市| 福贡县| 旺苍县| 福海县| 开封县| 金沙县| 宁陕县| 布拖县| 新安县| 易门县| 滕州市| 涟水县| 英吉沙县| 武川县| 子长县| 原平市| 伽师县| 延安市| 绥阳县| 承德市| 东兴市| 佛冈县| 泽普县| 罗山县| 宝兴县| 天门市| 永新县|