一、MongoDB聚合管道(Aggregation Pilpeline)

使用聚合管道可以对集合中的文档进行变换和组合。

主要功能:表的关联查询、数据统计

二、aggregate 管道操作符与表达式

管道操作符:

sql 和 nosql 对比:

管道表达式:

管道操作符作为“键”,所对应的“值”叫做管道表达式。

例如{$match:{status:"A"}}, $match 称为管道操作符, 而 status:"A"称为管道表达式,是管道操作符的操作数(Operand)。

三、数据模拟:

db.order.insert({"order_id":"","uid":,"trade_no":"","all_price":,"all_num":})
db.order.insert({"order_id":"","uid":,"trade_no":"","all_price":,"all_num":})
db.order.insert({"order_id":"","uid":,"trade_no":"","all_price":,"all_num":})
db.order_item.insert({"order_id":"","title":"商品鼠标 1","price":,num:})
db.order_item.insert({"order_id":"","title":"商品键盘 2","price":,num:})
db.order_item.insert({"order_id":"","title":"商品键盘 3","price":,num:})
db.order_item.insert({"order_id":"","title":"牛奶","price":,num:})
db.order_item.insert({"order_id":"","title":"酸奶","price":,num:})
db.order_item.insert({"order_id":"","title":"矿泉水","price":,num:})
db.order_item.insert({"order_id":"","title":"毛巾","price":,num:})

四、$project

修改文档的结构,可以用来重命名、增加或者删除文档中的字段

例如:要求查找order只返回trade_no和all_price字段

db.order.aggregate([
  {
    $project:{ trade_no:, all_price: }
  }
])

五、$match

用于过滤文档。类似where

db.order.aggregate([
  {
    $project:{ trade_no:, all_price: }
  },
  {
    $match:{"all_price":{$gte:}}
  }
])

六、$group

分组

统计每个订单的订单数量, 按照订单号分组

db.order_item.aggregate(
[
  {
    $group: {_id: "$order_id", total: {$sum: "$num"}}
  }
]

七、$sort

排序

-1:降序;1:升序

db.order.aggregate([
  {
    $project:{ trade_no:, all_price: }
  },
  {
    $match:{"all_price":{$gte:}}
  },
  {
    $sort:{"all_price":-}
  }
])

八、$limit

查询前几条

db.order.aggregate([
  {
    $project:{ trade_no:, all_price: }
  },
  {
    $match:{"all_price":{$gte:}}
  },
  {
    $sort:{"all_price":-}
  },
  {
    $limit:
  }
])

九、$skip

跳过几条

db.order.aggregate([
  {
    $project:{ trade_no:, all_price: }
  },
  {
    $match:{"all_price":{$gte:}}
  },
  {
    $sort:{"all_price":-}
  },{
    $skip:
  }
])

十、$lookup

表关联查询

db.order.aggregate([
  {
    $lookup:
      {
        from: "order_item",   //关联表
        localField: "order_id",  //主表的字段
        foreignField: "order_id",  //关联表的字段
        as: "items"  //存储的字段
      }
  }
])

当然也可以使用其他操作符

db.order.aggregate([
  {
    $lookup:{
      from: "order_item",
      localField: "order_id",
      foreignField: "order_id",
      as: "items"
     }
  },
  {
    $match:{"all_price":{$gte:}}
  }
])
db.order.aggregate([
  {
    $lookup:
    {
      from: "order_item",
      localField: "order_id",
      foreignField: "order_id",
      as: "items"
    }
  },
  {
    $project:{ trade_no:, all_price:,items: }
  },
  {
    $match:{"all_price":{$gte:}}
  },
  {
    $sort:{"all_price":-}
  },
])

十一、nodejs操作aggregate聚合管道

var MongoClient = require('mongodb').MongoClient;

//定义连接数据库的地址

const  url = 'mongodb://localhost:27017/';
var dbName = 'eggcms'; //连接数据库
MongoClient.connect(url,(err,client)=>{ if(err){
console.log('数据连接失败');
return false;
}
let db=client.db(dbName); /*获取db对象*/ db.collection("order").aggregate([
{
$lookup:
{
from: "order_item",
localField: "order_id",
foreignField: "order_id",
as: "items"
}
},
{
$match:{"all_price":{$gte:90}}
} ]).toArray(function(err,docs){
console.log(docs)
}) })

MongoDB学习day06--高级查询aggregate聚合管道和nodejs操作aggregate的更多相关文章

  1. MongoDB 高级查询_aggregate聚合管道

    MongoDB 聚合管道(AggregationPipeline) 使用聚合管道可以对集合中的文档进行变换和组合.实际项目应用主要是表关联查询.数据的统计. MongoDB 中使用 db.COLLEC ...

  2. MongoDB学习笔记六—查询下

    查询内嵌文档 数据准备 > db.blog.find().pretty() { "_id" : ObjectId("585694e4c5b0525a48a441b5 ...

  3. MongoDB学习(查找文档和其他数据查找操作)

    理解Cursor对象和查询运算符 cursor对象 cursor对象相当于一个指针,可通过迭代它来访问MongdoDB数据库中的一组对象. 在使用 find() 方法查询时,返回的并非实际文档,而是一 ...

  4. Mongodb - 解决 ( aggregate聚合管道 ) $match 根据 id 匹配 返回 [ ] 的问题

    需要对 id 进行转换 const mongoose = require('mongoose') var ObjectId = mongoose.Types.ObjectId;   await Use ...

  5. MongoDB学习(使用分组、聚合和映射-归并)

    使用分组.聚合和映射-归并 MongoDB的强大功能之一,是直接在服务器对文档的值进行复杂的操作,而不用先发文档发送到客户端在进行处理. 结果分组 对大型数据集进行查询操作时,通常会根据文档的字段值对 ...

  6. MongoDB学习笔记(11) --- 聚合

    MongoDB中聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果.有点类似sql语句中的 count(*) aggregate() 方法 MongoDB中聚 ...

  7. MongoDB学习笔记五—查询上

    数据准备 { , "goods_name" : "KD876", "createTime" : ISODate("2016-12- ...

  8. MongoDB中的高级查询(二)

    $mod取模运算 查询index对5取模运算等于1的数据. $not $not是元条件句,即可以用在任何其他条件之上.查询index对5取模运算不等于1的数据. $exists判断字段是否存在 查询出 ...

  9. MongoDB学习 (六):查询

    本文地址:http://www.cnblogs.com/egger/archive/2013/06/14/3135847.html  欢迎转载 ,请保留此链接๑•́ ₃•̀๑! 本文将介绍操作符的使用 ...

随机推荐

  1. vue同胞组件通讯解决方案(以下为一种另外可用vuex解决)

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  2. WEB前端JS与UI框架

    前端Js框架汇总 概述: 有些日子没有正襟危坐写博客了,互联网飞速发展的时代,技术更新迭代的速度也在加快.看着Java.Js.Swift在各领域心花路放,也是煞是羡慕.寻了寻.net的消息,也是振奋人 ...

  3. 使用python编写的简单远程管理软件

    因为用户可以选择是否同意被控制,所以并不算是木马. 使用python3.7,spyder,在windows 10 开发. client为控制端,server为被控端. 参考 mygithub http ...

  4. CAD交互绘制圆弧(网页版)

    在CAD设计时,需要绘制圆弧,用户可以在图面点圆弧起点,圆弧上的一点和圆弧的终点,这样就绘制出圆弧. 主要用到函数说明: _DMxDrawX::DrawArc2 由圆弧上的三点绘制一个圆弧.详细说明如 ...

  5. 字符串KMP || POJ 2185 Milking Grid

    求一个最小矩阵,经过复制能够覆盖原矩阵(覆盖,不是填充,复制之后可以有多的) *解法:横着竖着kmp,求最大公倍数的做法是不对的,见http://blog.sina.com.cn/s/blog_69c ...

  6. xlsx 读取文件日期问题

    xlsx 的版本:0.13.5,可以取到日期 xlsx 的版本:0.14.3,取到的日期转为数字了,没有找到方法转为日期, 可以开启   cellDates: true,但是这个时区不对, dateN ...

  7. 【lua实战摸索】在b.lua调用a.lua的函数

    需要掌握知识: lua table的使用(创建自己函数的表作为函数库) 普通函数的调用:tab.func(tab,参数) 等效于表中函数的调用tab:func(参数) 基本思路: 1.在相同目录下创建 ...

  8. spring boot 在idea中实现热部署

    1)在pom中直接引入依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifac ...

  9. URAL1966 Cipher Message 3

    题目描述 题解: 能看出来的是,每一组数只能改最后一位,所以前$7$位动不了. 所以$KMP$跑一跑. 重点在于最后一位怎么搞. 如果$KMP$跑完了还没找到合适的位置,直接$puts("N ...

  10. 关闭 macOS Google Chrome 黑暗模式风格

    终端执行命令 defaults write com.google.Chrome NSRequiresAquaSystemAppearance -bool YES 恢复 defaults write c ...