mongo同庫聯表查詢

源地址:mongo同庫聯表查詢
這裏只對同庫聯表查詢作介紹,跨庫聯表查詢可能在以後也會介紹(由於公司架構變更,以後可能會聯表查詢)
我用到的聯表查詢有兩種,一種是mongoose的populate,一種是$lookuphtml

populate

populate是使用外鍵關聯子表
例如如今有一張訂單表結構(動態外鍵):node

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失效
})

用戶表mongodb

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字段,固然也能夠在新建表的時候定義外鍵,這裏就不細說了mongoose

$lookup

lookup就是使用aggregate的$lookup屬性,直接上官網例子很是好懂
orders表ui

{ "_id" : 1, "item" : "abc", "price" : 12, "quantity" : 2 }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1 }
{ "_id" : 3  }

inventory表code

{ "_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以上貌似能夠轉,沒試過)htm

參考文章
Mongoose中的關聯表查詢 && 聚合查詢
在mongoose中填充外鍵ip

相關文章
相關標籤/搜索