千家信息网

mongodb中非常好用的Aggregate入门教程

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,前言aggregate 翻译过来是聚合的意思, 但是在实际的使用的它的体验特别像linux中的管道, 每个管道处理完之后再把结果交个下一个管道, 你的数据就像水流, 最后通过各个管道你能够得到你想要的
千家信息网最后更新 2025年01月20日mongodb中非常好用的Aggregate入门教程

前言

aggregate 翻译过来是聚合的意思, 但是在实际的使用的它的体验特别像linux中的管道, 每个管道处理完之后再把结果交个下一个管道, 你的数据就像水流, 最后通过各个管道你能够得到你想要的数据

我们一般用Aggregate做什么

aggregate查询文档

  • 聚合 平均数 等数据处理 group sum
  • 地理位置信息 $geoNear
  • 基本上mongodb的所有查询操作我们都可以用 aggregate实现, 用好这个基本上是万金油了

在这里我主要想记录一下mongodb在地理位置信息查询中使用到的技术,不仅可以查询到 距离 还可以按照距离排序

$geoNear 地理位置信息查询

首先我们的坐标数据在库里面怎么存, 类型为 Array , 记得加 2d 索引, 当然还有3d 索引, 目前还没有用到

 const storeschema = new mongoose.Schema({  name: { type: String, required: true },  point: { type: Array, required: true }, // [lon, lat] }); storeschema.index({ point: '2d' }); return mongoose.model('store', storechema);

然后按照就是地理查询代码了

this.ctx.model.Store.aggregate([{    $geoNear: {     spherical: true, // spherical 是否按照球形状来求距离     distanceMultiplier: 6378137,      maxDistance: 10000,     near: [ lon1, lat1 ],     distanceField: 'dist',     key: 'point',     query: {     }    }, }, //distanceMultiplier 这个参数是用于确定你返回的距离是什么单位 6378137 的单位是m //maxDistance 查询的最大距离 // near 中心点坐标// distanceField 距离放在哪个属性// key 保存坐标数据的地方// query 你的过滤条件                

有一个很有意思的地方是 match 所以在这里有一个 query属性来补齐这种遗憾

但是你可以在 后面 使用$match 对查到的所有地理位置信息数据做再一次的筛选

$lookup mongodb中的联表查询

$lookup 是在比较新的mongodb版本中才能使用的属性, 当然这个属性也是用于 aggregate中的, 它补齐了之前mongodb中无法联表的遗憾

看代码

await this.ctx.model.MemberInfo.aggregate([        {          $match: { store: new ObjectId(store) }        },        {          $lookup: {            from: 'users',            localField: 'user',            foreignField: '_id',            as: 'user'          }        },        {          $replaceRoot: { newRoot: { $mergeObjects: [{ $arrayElemAt: [ '$user', 0 ] }, '$$ROOT' ] } }        },        {          $match: { 'certification.name': { $regex: search } }        },        {          $project: { _id: 1 }        }      ]);

memberinfo 与 user 表在这里我想要获取 memberinfo localField: 'user' 为外键对应 user表 foreignField: '_id' _id字段他的额外属性...

说白了 我的会员表里面只存了用户的id 现在我想要拿到用户的 其它信息...

附上链接吧 $lookup

写在最后

当然说他是查询万金油他当然支持 定义数据的输出 limit $sort 等常规操作

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。

查询 数据 信息 地理 属性 位置 地理位置 管道 坐标 遗憾 万金 万金油 代码 内容 单位 地方 就是 是在 用户 索引 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 apache搭建服务器 临沂嘉瑞网络技术有限公司 天津拓宇数字网络技术 网络安全大会照片 天津定制软件开发解决方案 2022学数据库装什么软件 协同软件开发费用多少钱 网络安全调研会议主持词 福建服务器硬盘报价 易迅通网络技术有限公司 各种数据库文件格式转换 计算机网络技术目标路径设计 一个服务器可安装多个数据库吗 网络技术专业好就业么 主从数据库与缓存 魔兽世界数据库6.2 报网络安全专业主要学什么 平谷区技术软件开发大概费用 淮北软件开发培训费用 电脑网络安全模式有啥用 网络技术是多媒体技术 2016年4月19日网络安全和信息化 上海现代化软件开发收费 vb数据库控件 如何用服务器上传图片 远程服务器管理是什么 软件开发公司技术入股合同 地州市公安局网络安全保护中心 百威网络技术有限公司怎么样 中兴bbu系统部软件开发
0