一、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. SQL Server2012 T-SQL对分页的增强尝试

    简介 SQL Server 2012中在Order By子句之后新增了OFFSET和FETCH子句来限制输出的行数从而达到了分页效果.相比较SQL Server 2005/2008的ROW_Numbe ...

  2. (转)Spring+JDBC组合开发

    http://blog.csdn.net/yerenyuan_pku/article/details/52882435 搭建和配置Spring与JDBC整合的环境 使用Spring+JDBC集成步骤如 ...

  3. String系列之replaceAll方法替换.

    直接使用String类的replaceall方法的第一个参数并不是简单的字符串,而是一个正则表达式.在正则表达式中,英文点号(.)表示任意字符,所以你原先的写法会把所有字符都替换成空白. 转义使用所以 ...

  4. docker 镜像管理操作

    镜像特点 1. 分层存储的文件 2.一个软件运行环境 3.一个镜像可以创建多个容器 4.一种标准交付 5.不包含Linux内核而又精简的Linux操作系统 6.不是一个单一的文件而是由多层构成的,可以 ...

  5. 新时代web组件开发标准

    VUE框架,则是遵行了这个标准. 1.html文件 <!DOCTYPE html><html><head lang="en"> <meta ...

  6. Caused by: java.lang.ClassNotFoundException: Cannot find class: User

    源代码: <select id="selectAll" resultType="User"> select user_id uid,user_nam ...

  7. [模板] Exgcd

    求解一组ax+bc=gcd(a,b) #include<iostream> #include<cstdio> using namespace std; int exgcd(in ...

  8. MySQL 8.0.12 基于Windows 安装教程

    第一步:到MySQL官网下载安装包:https://dev.mysql.com/downloads/mysql/ 第二步:将下载好的安装包(mysql-8.0.12-winx64 .zip)解压到相应 ...

  9. 专访Vue作者尤雨溪:Vue CLI 3.0重构的原因

    1.为什么要对 Vue CLI 进行大规模修改? 尤雨溪认为旧版本的 Vue CLI 本质上只是从 GitHub 拉取模版,这种拉模版的方式有几个问题: (1) 在单个模版里面同时支持太多选项会导致模 ...

  10. 条款24:若所有参数皆需要类型转换,请为此采用non-member函数(Declare non-member functions when type conversions should apply to all parameters)

    NOTE: 1.如果你需要为某个函数的所有参数(包括this指针所指的那个隐喻参数)进行类型转换,那么这个函数必须是个non-member.