欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2017年08月14日 10:41:51   作者:masongzhi  
在關(guān)系型數(shù)據(jù)庫中,通過連接運(yùn)算符可以實(shí)現(xiàn)多個(gè)表聯(lián)合查詢。而非關(guān)系型數(shù)據(jù)庫的特點(diǎn)是表之間屬于弱關(guān)聯(lián),下面這篇文章主要給大家介紹了關(guān)于mongodb實(shí)現(xiàn)同庫聯(lián)表查詢的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。

前言

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

注意:這里只對同庫聯(lián)表查詢做介紹,跨庫聯(lián)表查詢可能在之后也會介紹(因?yàn)楣炯軜?gòu)變動(dòng),之后可能會聯(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中填充外鍵

相關(guān)文章

  • MongoDB創(chuàng)建與刪除數(shù)據(jù)庫

    MongoDB創(chuàng)建與刪除數(shù)據(jù)庫

    這篇文章介紹了MongoDB創(chuàng)建與刪除數(shù)據(jù)庫的方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • 淺談MongoDB內(nèi)部的存儲原理

    淺談MongoDB內(nèi)部的存儲原理

    這篇文章主要介紹了淺談MongoDB內(nèi)部的存儲原理,MongoDB是一個(gè)面向文檔的數(shù)據(jù)庫系統(tǒng)。使用C++編寫,不支持SQL,但有自己功能強(qiáng)大的查詢語法,需要的朋友可以參考下
    2023-07-07
  • MongoDB系列教程(五):mongo語法和mysql語法對比學(xué)習(xí)

    MongoDB系列教程(五):mongo語法和mysql語法對比學(xué)習(xí)

    這篇文章主要介紹了MongoDB系列教程(五):mongo語法和mysql語法對比學(xué)習(xí),本文對熟悉Mysql數(shù)據(jù)庫的同學(xué)來說幫助很大,用對比的方式可以快速學(xué)習(xí)到MongoDB的命令,需要的朋友可以參考下
    2015-05-05
  • MongoDB慢查詢與索引實(shí)例詳解

    MongoDB慢查詢與索引實(shí)例詳解

    索引通常能夠極大的提高查詢的效率,這篇文章主要給大家介紹了關(guān)于MongoDB慢查詢與索引的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • mongoDB數(shù)據(jù)庫索引快速入門指南

    mongoDB數(shù)據(jù)庫索引快速入門指南

    索引是一種特殊的數(shù)據(jù)結(jié)構(gòu),存儲設(shè)置在一個(gè)易于遍歷形式的數(shù)據(jù)的一小部分。索引存儲一個(gè)特定的字段或一組字段的值,在索引中指定的值的字段排列的,對mongoDB索引相關(guān)知識感興趣的朋友跟隨小編一起學(xué)習(xí)下吧
    2022-03-03
  • MongoDB數(shù)據(jù)庫的日志文件深入分析

    MongoDB數(shù)據(jù)庫的日志文件深入分析

    這篇文章主要給大家介紹了關(guān)于MongoDB數(shù)據(jù)庫日志的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用MongoDB具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-09-09
  • MongoDB創(chuàng)建一個(gè)索引而性能提升1000倍示例代碼

    MongoDB創(chuàng)建一個(gè)索引而性能提升1000倍示例代碼

    這篇文章主要給大家介紹了關(guān)于如何在MongoDB中創(chuàng)建一個(gè)索引而性能提升1000倍的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • Laravel?框架中使用?MongoDB?數(shù)據(jù)庫的操作

    Laravel?框架中使用?MongoDB?數(shù)據(jù)庫的操作

    這篇文章主要介紹了Laravel?框架中使用?MongoDB?數(shù)據(jù)庫的問題及操作方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • MongoDB 游標(biāo)詳解及實(shí)例代碼

    MongoDB 游標(biāo)詳解及實(shí)例代碼

    這篇文章主要介紹了 MongoDB 游標(biāo)詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • MongoDB下根據(jù)數(shù)組大小進(jìn)行查詢的方法

    MongoDB下根據(jù)數(shù)組大小進(jìn)行查詢的方法

    這篇文章主要介紹了MongoDB下根據(jù)數(shù)組大小進(jìn)行查詢的方法,分別實(shí)現(xiàn)了指定大小的數(shù)組和某個(gè)范圍的數(shù)組,需要的朋友可以參考下
    2014-04-04

最新評論