MongoDB聚合查询之分段分组查询统计
简介MongoDB聚合查询之分段分组查询统计
在Mysql中我们经常会用到给某一个字段进行分段统计,然而在MongoDB数据库去处理这个统计应该如何做呢?
数据源说明:
- data:表示集合
- date:表示集合中的日期
- satisfaction:表示集合中的满意度
需求:
- 查询不同满意度分段的人数
db.getCollection("data").aggregate([{
$match: {
date: 20200604
}
}, {
$project: {
"count_field":
{
$switch: {
branches: [
{
case: {
$eq: ["$satisfaction", 100]
},
then: "100"
},
{
case: {
$and: [{
$gte: ["$satisfaction", 95]
}, {
$lte: ["$satisfaction", 100]
}]
},
then: "[95,100)"
},
{
case: {
$and: [{
$gte: ["$satisfaction", 90]
}, {
$lte: ["$satisfaction", 95]
}]
},
then: "[90,95)"
},
{
case: {
$and: [{
$gte: ["$satisfaction", 85]
}, {
$lte: ["$satisfaction", 90]
}]
},
then: "[85,90)"
},
{
case: {
$and: [{
$gte: ["$satisfaction", 80]
}, {
$lte: ["$satisfaction", 85]
}]
},
then: "[80,85)"
},
{
case: {
$eq: ["$satisfaction", 0]
},
then: "0"
},
],
default: "(0,80)"
}
}
}
}, {
$group: {
_id: "$count_field",
"总数": {
$sum: 1
}
}
}, {
$sort: {
"_id":1
}
}])
查询说明:
- match:条件匹配
- project:核心部分,这里使用了switch,进行条件判断,branches是固定的写法,不要修改
- group:进行分组,根据project中的字段count_field作为分组字段
- sort:排序,根据group中的_id
结果展示:

我们在工作或是生活中,有时会需要制作一些请柬、奖状、或者桌牌等,这些东西都有一个共性,那就是除了每个人的名字不一样之外,其他大部分内容都是一样的,那么我们可以如何快速地批量制作呢?很简单,用Word的邮件合并功能就能做到!
最近关注流媒体服务器来做网络直播,本想使用阿里云的流媒体服务器,由于费用的问题还是想能否自己搭建一个流媒体服务器供自己测试使用。果不其然,Nginx居然如此强大,可以用来做流媒体服务器。本文将具体介绍流媒体服务器的搭建过程和使用过程。
MongoDB聚合查询之分段分组查询统计
OpenCV-Python图像类型转换是用cv2.cvtcolor()函数,用于将图像从一个颜色空间转换为另一个颜色空间。它的参数包括输入图像、目标颜色空间和转换方式。例如,将RGB图像转换为灰度图像可以使用cv2.COLOR_RGB2GRAY作为转换方式。
人脸识别技术如今已广泛应用于安全监控、身份验证、人机交互等多个领域。对于开发者而言,利用现有的库如face_recognition可以极大地简化人脸识别的开发过程。本文将详细介绍如何安装face_recognition库,并通过实例展示如何用它来实现一个基本的人脸比对服务。
快速生成表格
Electron页面跳转、浏览器打开链接和打开新窗口
在使用Git的过程中,不想每次都输入用户名和密码去拉取代码,所以就需要保存这些信息,那么既然有保存了,就必须有清除功能。
在Mac电脑中,如何对Git的用户名和密码进行修改呢?起初不懂Mac,所以整了很久,本文将记录如何对这个进行操作,以便后期使用。
Docker编译镜像出现:fetch http://dl-cdn.alpinelinux.org/alpine/v3.12/main/x86_64/APKINDEX.tar.gz
ERROR: http://dl-cdn.alpinelinux.org/alpine/v3.12/main: temporary error (try again later)
WARNING: Ignoring APKINDEX.2c4ac24e.tar.gz: No such file or directory问题