第23章:MongoDB-聚合操作--聚合命令
范例:统计students表中的数据量
db.students.count();
范例:模糊查询
db.students.count("name":/张/i);
范例:求某个字段不同的值
db.students.distinct("name");
db.runCommand({"distinct":"students","key":"name"});
key: 用于指定要分组的键
initial: 对于分组统计的字段设置键名和初始值
reduce: 循环每个分组中的每个文档,一组循环完了会继续下一组
condition:用于分组前筛选掉不满足条件的文档
finalize: 用于对分组后的结果进一步处理,每组都会调用finalize
db.articles.group({
"key": {"author": true},
"initial": {"sum": 0},
"reduce": function(doc, prev) {
if(doc.like > 10) {
prev.sum += 1;
}
}
})
[
{
"author" : "zhangsan",
"sum" : 2
},
{
"author" : "lisi",
"sum" : 2
},
{
"author" : "mengday",
"sum" : 0
}
]
db.articles.group({
"key": {"author": true},
"initial": {"sum": 0},
"reduce": function(doc, prev) {
if(doc.like > 10) {
prev.sum += 1;
}
},
"condition":{"author": {"$ne": "mengday"}}
})
[
{
"author" : "zhangsan",
"sum" : 2
},
{
"author" : "lisi",
"sum" : 2
}
]
db.articles.group({
"key": {"author": true},
"initial": {"sum": 0},
"reduce": function(doc, prev) {
if(doc.like > 10) {
prev.sum += 1;
}
},
"condition":{"author": {"$ne": "mengday"}},
"finalize": function(doc){
if(doc.author == "zhangsan"){
delete doc
}
}
})
[
{
"author" : "zhangsan",
"sum" : 3
},
{
"author" : "lisi",
"sum" : 2
}
]
范例:查询所有年龄大于等于19岁的学生信息,并且按照年龄分组
db.runCommand({"group":{
"ns":"students",//集合
"key":{"age":true},//按照age分组
"initial":{"count":0},//默认数量为0
"condition":{"age":{"$gt":19}},//条件
"$reduce":function(doc,prev){//完成后的操作
prev.count ++;
}
}});
第23章:MongoDB-聚合操作--聚合命令的更多相关文章
- mongodb客户端操作常用命令(续)
之前有写过一篇mongodb客户端的操作常用命令 ,今天接着来记录分享一些关于mongodb账户权限设置的命令操作 上期mongodb客户端的操作常用命令地址:https://www.cnblogs. ...
- MongoDB的Spring-data-mongodb集成(Win10 x64) 第一章 - MongoDB安装与简单命令
这是MongoDB系列的第一章,作者将持续更新. 1.下载 https://www.mongodb.com/download-center#community 2.安装与配置 有关安装的任何困难请点击 ...
- mongodb客户端操作常用命令
一启动mongodb数据库mongod --dbpath E:\mongo\data\db(这里些自己的mongodb数据库存放目录)二客户端操作1.显示数据库集合show dbs2.新建数据库use ...
- mongodb数据库操作 python+命令行
一.python操作 from bson.objectid import ObjectId import pymongo client1 = pymongo.MongoClient(host=) ...
- [Python设计模式] 第23章 烤串的哲学——命令模式
github地址:https://github.com/cheesezh/python_design_patterns 题目1 用程序模拟,顾客直接向烤串师傅提需求. class Barbecuer( ...
- .NET LINQ 聚合操作
聚合操作 聚合运算从值集合计算单个值. 从一个月的日温度值计算日平均温度就是聚合运算的一个示例. 方法 方法名 说明 C# 查询表达式语法 Visual Basic 查询表达式语法 更多信息 ...
- MongoDB的聚合操作以及与Python的交互
上一篇主要介绍了MongoDB的基本操作,包括创建.插入.保存.更新和查询等,链接为MongoDB基本操作. 在本文中主要介绍MongoDB的聚合以及与Python的交互. MongoDB聚合 什么是 ...
- MongoDB 基本操作和聚合操作
一 . MongoDB 基本操作 基本操作可以简单分为查询.插入.更新.删除. 1 文档查询 作用 MySQL SQL MongoDB 所有记录 SELECT * FROM users; db ...
- MongoDB中的聚合操作
根据MongoDB的文档描述,在MongoDB的聚合操作中,有以下五个聚合命令. 其中,count.distinct和group会提供很基本的功能,至于其他的高级聚合功能(sum.average.ma ...
- MongoDB入门---聚合操作&管道操作符&索引的使用
经过前段时间的学习呢,我们对MongoDB有了一个大概的了解,接下来就要开始使用稍稍深入一点的东西了,首先呢,就是MongoDB中的聚合函数,跟mysql中的count等函数差不多.话不多说哈,我们先 ...
随机推荐
- 将之前的Power idea公司的数据按照下图所示的格式在屏幕上显示出来。
之前的文章 示例代码如下 assume cs:codesg ;将整个data段看作是一个数组,长度一共为 ;21*4+21*4+2*21=168+42=210字节 data segment db ' ...
- Linux移植之内核启动过程引导阶段分析
在Linux移植之make uImage编译过程分析中已经提到了uImage是一个压缩的包并且内含压缩程序,可以进行自解压.自解压完成之后内核代码从物理地址为0x30008000处开始运行.下面分析在 ...
- 单元测试使用spring注解获取bean
在实际项目开发中经常会有单元测试,单元测试中经常会用类似这样的代码片段获取spring管理的bean @Test public void testSendEmail(){ MessageService ...
- Attribute Syntax
Attribute Syntax This section describes the syntax with which __attribute__ may be used, and the con ...
- 1、javaweb学习之配置文件web.xml
今天这里主要讲述javaweb中的配置文件web.xml中的内容及其作用,都是基础部分,对于初学者需要好好掌握理解. 简单配置: <servlet> <servlet-name ...
- Cmder安装配置
转: 1)Windows 命令行增强 cmder chocolatey 配置指南 2) Windows必备神器Cmder使用教程 3)Windows上的程序员神器——Cmder 4)Windows命令 ...
- Android.Tools.Eclipse hangs at the Android SDK Content Loader
Eclipse hangs at the Android SDK Content Loader http://stackoverflow.com/questions/13489141/eclipse- ...
- iOS push新的调用方法
// IOS8 新系统需要使用新的代码if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 8.0){ [[UIAppl ...
- RAPID程序设计
1.ABB机器人软件 RobotWare 是ABB提供的机器人系列应用软件的总称. RobotStudio是ABB公司自行开发的机器人模拟软件, 能在PC机上模拟几乎所有型号的ABB 机器人几乎所有的 ...
- Spring 注解驱动(二)Servlet 3.0 注解驱动在 Spring MVC 中的应用
Spring 注解驱动(二)Servlet 3.0 注解驱动在 Spring MVC 中的应用 Spring 系列目录(https://www.cnblogs.com/binarylei/p/1019 ...