好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > mongodb實現同庫聯表查詢方法示例

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

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

前言

最近在工作中遇到一個問題,需要對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中填充外鍵

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

標簽:無錫 自貢 雞西 玉林 遼陽 興安盟 廈門 泰安

巨人網絡通訊聲明:本文標題《mongodb實現同庫聯表查詢方法示例》,本文關鍵詞  mongodb,實現,同庫,聯表,查詢,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《mongodb實現同庫聯表查詢方法示例》相關的同類信息!
  • 本頁收集關于mongodb實現同庫聯表查詢方法示例的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 国产又色又爽又黄的视频在线播放| 婷婷成人亚洲综合国产| 朋友的丰满人妻HD中文| 韩国年轻漂亮岳每4乱理| 国产精品久久久久久久久福利| 色多多视频污| 国产午夜福利精品久久不卡完整版bd高清| 亚洲欧洲日韩在线| 色台湾色综合网站| 男女猛烈的拍拍拍拍拍拍拍| 少妇精品久久久一区二区三区 | 波多野结衣一道本| 亚洲欧美国产精品| 娇妻被抵住宫口注入浓精受孕| 亚洲AV无码乱码A片无码老司姬| 亚洲精品视频二区| 一二三四在线播放视频国语版| 360水滴拍小两口4次| 最近2019中文字幕第二页| 亚洲毛片一级带毛片基地| 伊人啪啪网| 肉丝超薄少妇一区二区三区| JIZZ学生18丝袜中国老师| 自拍视频一区二区| xxxx.av| 黄一级| jiizzjiizz老师水好多| 亚洲色少妇熟女| 黄色小说描写| 入禽太深免费看在线观看| 亚洲草逼| 国精产品一区一区三区有限公司 | 三级4级全黄裸黄| 国产高清成人mv在线观看| 三攻一受4p巨肉寝室腐文| 女教师大荫蒂毛茸茸| 欧美150p| 男女扒开双腿猛进入免费网站| 两女一杯在线观看| 国产精品无遮挡观看在线| 亲生(H)辣文h|