• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    mongodb实现同库联表查询方法示例

    前言

    最近在工作中遇到一个问题,需要对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多表关联查询操作实例详解
    上一篇:mongodb3.4集群搭建实战之高可用的分片+副本集
    下一篇:详解mongoDB主从复制搭建详细过程
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    mongodb实现同库联表查询方法示例 mongodb,实现,同库,联表,查询,