【数据库】通过实例讲清楚,Mongodb的增删查改,分组查询,聚合查询aggregate
目录
一.基础概念
二.数据库的管理
1.创建数据库
2.删除数据库
二.集合的管理
1.显示所有集合
2.创建集合
3.删除当前集合
4.向集合中插入元素
三.文档的管理
1.文档插入
2.文档的更新
3.文档的删除
4.文档查询
(1)查询基本语法:
(2)查询table2集合下的所有文档
(3)查询table2集合下的所有name为zhangsan的记录
(4)查询table2集合下name为zhangsan的其中一个记录
(5)查询结果中的某些列
(6)and操作
(7)or操作
(8)大于小于,等于操作
(9)in,not in
(10)查询空值
(11)匹配查询
(12)使用distinct去重
(13)查询集合中的文档数
四.aggregate() 聚合操作
<1>管道操作如下:
<2>聚合表达式:
<3>通过实例讲清楚,直接看代码:
<4>准备数据
<5>查询案例以及语句,共12个
注意点:
一.基础概念
mongodb中,基本的概念是文档,集合,数据库。
序号 | 基本概念 | 说明 |
---|---|---|
1 | database | 数据库 |
2 | collection | 集合,也称文档组,相当于mysql中的表table |
3 | ducument | 文档,相当于mysql表中的行,键值对结构,BSON(binary二进制) |
4 | field | 字段,也就是mysql表中的列 |
5 | index | 索引 |
关于主键的说明:MongoDB自动将_id字段设置为主键。MongoDB不支持表的连接。
一个mongodb可以建立多个数据库,一个数据库可以创建多个集合,一个集合很总可以有多个文档,数据库存储在data中。
二.数据库的管理
1.创建数据库
创建数据库使用关键字use,创建并指定当前数据库,具体语法如下:
# 1.创建数据库,例如创建并指定一个school数据库
use <databasename>use school# 2.查看当前数据库
db# 3.查看所有数据库
show dbs
2.删除数据库
# 1.先选中是哪个数据库
use school# 2.删除数据库
db.dropDatabase()
二.集合的管理
集合相当于Mysql中的表结构table.
1.显示所有集合
# 1.显示所有集合(表结构)
show tables;
show collections
2.创建集合
# name是创建的集合名,option是可选参数,指定有关内存大小及索引的选项
db.createCollection(name,option):
3.删除当前集合
db.school.drop()
4.向集合中插入元素
# 1.向集合中插入单个元素,insertOne({k:v})
db.collection001.insertOne({"name":"jack"})# 2.向集合中插入多个元素,insertMany({k1:v1},{k2:v2}......)
db.collection001.insertOne({"name":"jack"},{"age":18})
三.文档的管理
文档也就是mysql中的行
1.文档插入
每条文档在插入的时候,MongoDB都会维护一个_id作为唯一标识,_id默认会自动生成。
# 1.插入1行
db.table2.insertOne({"name":"zhangsan"})# 2.插入多行
db.table2.insertMany([
{"name":"zhangsan","age":15,"address":"xuzhou"},
{"name":"wangwu","age":20,"address":"nanj"}
])# 3.当然也可以是这种形式的
document = ({"name":"wangwu","age":20,"address":"nanj",tags:['mysql','oracle'],like:100})
db.table2.insertMany([document])
2.文档的更新
文档的更新都是先查出来,再更新。
<query>:update的查询条件,类似sql update查询内的where后面的条件
<update>:update的对象和一些更新的操作符,也可以理解为sql update查询内set后面的
upsert:可选,如果不存在update记录,是否插入objNew,true是插入,false不插入
multi:可选,mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新 5.0之后是废弃的
writeConcern:可选,抛出异常的级别
db.collection.update(<query>, // 相当于where操作<update>, // 相当于set操作{upsert: <boolean>,multi: <boolean>,writeConcern: <document>}
)
注意语法:$set
// 先查再更新,$set是set// 更新一条,updateOnedb.table3.updateOne({title:"Oracle"},{$set:{title:"MongoDB是NoSQL键-值数据库"}})
3.文档的删除
// 删除集合下的所有文档
db.collection.deleteMany ({})// 删除status等于A的所有文档
db.collection.deleteMany ({ status : "A" })// 删除status等于D的一个文档
db.collection.delete.One ({ status : "D" })// 当然也可以根据主键删除
db.table2.deleteOne({_id:ObjectId("64ef1442db2b4f63a830119c")})
4.文档查询
文档的查询十分重要,用的最多。
MongoDB查询文档使用find方法,find()方法以非结构化的方式来显示所有文档。
语法:
db.集合名称.find({<query>},....)
等于,不等于,大于等于,大于,小于等于,小于等,看下表:
操作 | 格式 | 例子 | mysql类比语句 |
等于 | {key:value} | db.集合名称.find({name:"zhangsan"}) | where name='zhangsan' |
不等于 | {key:{$ne:value}} | db.集合名称.find({age:{$ne:18}}) | where age != 18 |
小于 | {key:{$lt:value}} | db.集合名称.find({age:{$lt:18}}) | where age < 18 |
小于等于 | {key:{$lte:value}} | db.集合名称.find({age:{$lte:18}}) | where age <= 18 |
大于 | {key:{$gt:value}} | db.集合名称.find({age:{$gt:18}}) | where age > 18 |
大于等于 | {key:{$gte:value}} | db.集合名称.find({age:{$gte:18}}) | where age >= 18 |
(1)查询基本语法:
第一个{}放的是where条件,第二个放的是显示哪些列,或者不显示哪些列,列的值设置为0表示不显示,设置为1设置为显示。
db.table2.find({},{})
(2)查询table2集合下的所有文档
db.table2.find()
(3)查询table2集合下的所有name为zhangsan的记录
等值查询,name="zhangsan"
db.table2.find({name:"zhangsan"})
(4)查询table2集合下name为zhangsan的其中一个记录
db.table2.findOne({name:"zhangsan"})
(5)查询结果中的某些列
默认为0,0表示不显示,1表示显示该列,1和0是不能同时用的
相当于select name,address from table2
db.table2.find({},{name:1,address:1}) db.table2.find({name:'zhangsan'},{name:1,age:1,address:1,by:1})
(6)and操作
逗号链接,
db.table2.find({name:'zhangsan',age:"lisi"},{name:1,age:1,address:1})
select name,age,address from table2 where name = "zhangsan" and age = "lisi"
(7)or操作
需要在条件前加$or
db.table2.find({$or:[{age:"lisi"},{address:"xuzhou"}]},{name:1,age:1,address:1})
(8)大于小于,等于操作
db.table2.find({age:{$gte:11,$lte:100}})
(9)in,not in
db.table2.find({age:{$in:[10,15,20,18,12]}})
(10)查询空值
db.table2.find({age:null})
(11)匹配查询
// 以zha开头的相当于like"zha%
db.table2.find({name:/^zha/})// 相当于like"%zha%
db.table2.find({name:/zha/})
(12)使用distinct去重
db.table2.distinct('name')
// 相当于select distinct(name) from table2
(13)查询集合中的文档数
db.table2.count()
四.aggregate() 聚合操作
整个聚合的过程称为管道,由多个步骤构成。一个一个的管道,也就是聚合的步骤,上一个管道操作的结果可以作为下一个管道的初始数据。每一个中间结果都是一个{}
一个管道操作由2分布构成,管道操作,聚合表达式处理 。
<1>管道操作如下:
- $group:将集合中的文档分组,用于统计结果,_id键对应的值是根据什么分组
- $match:用于过滤数据,只输出复合条件的文档,$match使用MongoDB的标准查询操作,相当于where,having条件来过滤数据的
- $project:修改输入文档的结构,可以用来重命名,增加或删除域,也用于创建计算结果以及嵌套文档。 简单来说选择显示哪些元素,0代表不显示,1代表显示
- $limit:用来限制MongoDB聚合管道返回的文档数
- $skip:在聚合管道中跳过指定数量的文档,并返回余下的文档。 $sort:将输入的文档排序后输出,1是升序排序,-1是降序排序
- $unwind:将文档中的某个数组类型字段拆分成多条,产生多个文档,每条包含数组中的一个值
<2>聚合表达式:
- $sum:计算总和
- $avg:计算平均值
- $min:获取集合中所有文档对应值的最小值
- $max:获取集合中所有文档对应值的最大值
- $push:在结果文档中插入值到一个数组中
- $first:根据资源文档的排序获取第一个文档数据
- $last:根据资源文档的排序获取最后一个文档数据
语法:一个大括号表示一个管道处理{}
db.集合名称.aggregate([
{管道操作1:{表达式处理1}},
{管道操作2:{表达式处理1}},
{......}])
<3>通过实例讲清楚,直接看代码:
<4>准备数据
db.persons.insertMany([{name:"zhangsan",gender:"man",high:180,weight:75,salary:5800,hobby:["basketball","music","money"]},{name:"lisi",gender:"man",high:175,weight:70,salary:6000,hobby:["run","music","money"]},{name:"wangwu",gender:"man",high:178,weight:73,salary:6800,hobby:["video","football","money"]},{name:"zhaoliu",gender:"man",high:160,weight:70,salary:8000,hobby:["video","football","money"]},{name:"lili",gender:"woman",high:160,weight:60,salary:5000,hobby:["video","money"]},{name:"lingling",gender:"woman",high:165,weight:63,salary:6000,hobby:["video","music"]},{name:"jingjing",gender:"woman",high:158,weight:58,salary:5500,hobby:["music","book","run"]},{name:"cuicui",gender:"man",high:178,weight:80,salary:9500,hobby:["video","football","money"]},{name:"xiaohei",gender:"man",high:183,weight:85,salary:6800,hobby:["football","money"]}
])
<5>查询案例以及语句,共12个
注意点:
- $sum:1 是文档中出现一个符合条件的就+1
- 最外部的每个{}是一个管道操作,都需要加$,_id是根据什么来分组,里面再由处理表达式具体处理,别忘记加$
- value取值的时候:"$name",别忘记加$
- 注意value为0,1的操作
// 1.统计出男女生的人数
db.persons.aggregate([{$group:{// _id是根据什么来分组_id:"$gender",// 对性别进行分组,根据每一组符合条件的出现一个文档+1,counter:{$sum:1}}}
])
// 2.统计出男女生身高总数
db.persons.aggregate([{$group:{_id:"$gender",// 对每一组的符合条件的进行求和counter:{$sum:"$high"}}}
])// 3.统计出男女生平均身高
db.persons.aggregate([{$group:{_id:"$gender",counter:{$avg:"$high"}}}
])// 4.分别找出男女生第一个出现的人的身高
db.persons.aggregate([{$group:{_id:"$gender",firster:{$first:"$high"}}}
])
db.persons.find()// 5.分别找出男女生最后一个出现的人的身高,$first,$last,只关注的是每组的第一个,最后一个
db.persons.aggregate([{$group:{_id:"$gender",laster:{$last:"$high"}}}
])
// 6.分别找出男女生最高的身高
db.persons.aggregate([{$group:{_id:"$gender",highest:{$max:"$high"}}}
])
// 7.分别找出男女生最矮的身高
db.persons.aggregate([{$group:{_id:"$gender",lowest:{$min:"$high"}}}
])// 8.按照男女生分类将身高分别放在数组中
db.persons.aggregate([{$group:{_id:"$gender",arr:{$push:"$high"}}}
])// 9.查询身高>160的男女生人数
db.persons.aggregate([{$match:{high:{$gt:160}}},{$group:{_id:"$gender",counter:{$sum:1}}}
])
db.persons.find()
// 10.查询身高>160的男女生人数,只输出人数,限制输出的字段,$project,限制查询字段,0是不输出的字段,1是输出字段
db.persons.aggregate([{$match:{// high:属性的字段high:{$gt:160}}},{$group:{_id:"$gender",counter:{$sum:1}}},{$project:{_id:0,counter:1}}
])// 11.将男女生的人数排序输出,counter:1是正序输出,-1是倒序输出
db.persons.aggregate([{$group:{_id:"$gender",counter:{$sum:1}}},{$sort:{counter:-1}},{$project:{_id:0,counter:1}}])// 12.对男生按照身高进行排序,输出3到5名的姓名和身高
db.persons.aggregate([{$match:{gender:"man"}},{$sort:{high:1}},{$skip:2},{$limit:3},{// 选择显示哪些元素,0代表不显示,1代表显示$project:{_id:0,name:1,high:1}}
])
ok,基本上敲完就知道MongoDB的聚合查询咋回事了
相关文章:

【数据库】通过实例讲清楚,Mongodb的增删查改,分组查询,聚合查询aggregate
目录 一.基础概念 二.数据库的管理 1.创建数据库 2.删除数据库 二.集合的管理 1.显示所有集合 2.创建集合 3.删除当前集合 4.向集合中插入元素 三.文档的管理 1.文档插入 2.文档的更新 3.文档的删除 4.文档查询 (1)查询基本语法࿱…...

vue + video.js 加载多种视频流(HLS、FLV、RTMP、RTSP)
起因: 由于需要在一个项目内接入多种常用的视频流,所以接触到video.js,这里就做个记录。 框架: vue2 video.js videojs-contrib-hls videojs-flvjs-es6 videojs-flash video-js.swf vue安装就不讲了,直接从项目…...

用 Python 微调 ChatGPT (GPT-3.5 Turbo)
用 Python 微调 ChatGPT (GPT-3.5 Turbo) 备受期待的 GPT-3.5 Turbo 微调功能现已推出,并且为今年秋季即将发布的 GPT-4 微调功能奠定了基础。 这不仅仅是一次简单的更新——它是一个游戏规则改变者,为开发人员提供了完美定制人工智能模型的关键解决方案…...

单目标应用:基于蜘蛛蜂优化算法(Spider wasp optimizer,SWO)的微电网优化调度MATLAB
一、微网系统运行优化模型 微电网优化模型介绍: 微电网多目标优化调度模型简介_IT猿手的博客-CSDN博客 二、蜘蛛蜂优化算法 蜘蛛蜂优化算法(Spider wasp optimizer,SWO)由Mohamed Abdel-Basset等人于2023年提出,该…...

2023年7月京东饮料行业数据分析(京东运营数据分析)
饮料消费已成为当下快消品行业里的主力军,随着社会群体喜好的改变、消费群体的不断扩大,可选择的饮料种类越来越多,我国饮料市场的体量也较为庞大。根据鲸参谋电商数据分析平台的数据显示,今年7月份,京东平台饮料的销量…...

执行 JUnit 单元测试前,修改环境变量
同一份代码,在不改变配置文件的情况下,可以连接不同的数据库,进行JUnit测试。 非开发、测试、生产环境的区别。而是 我就站在这里,指哪打哪! 避免重复造轮子,参考博文: 使用junit&spri…...

openGauss学习笔记-63 openGauss 数据库管理-资源池化架构
文章目录 openGauss学习笔记-63 openGauss 数据库管理-资源池化架构 openGauss学习笔记-63 openGauss 数据库管理-资源池化架构 本文档主要介绍资源池化架构下的一些最佳实践和使用注意事项,用于支撑对相关特性感兴趣的开发者可以快速部署、实践或进行定制化开发。…...

计算机竞赛 基于深度学习的植物识别算法 - cnn opencv python
文章目录 0 前言1 课题背景2 具体实现3 数据收集和处理3 MobileNetV2网络4 损失函数softmax 交叉熵4.1 softmax函数4.2 交叉熵损失函数 5 优化器SGD6 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 **基于深度学习的植物识别算法 ** …...

ChatGPT如何应对紧急情况和灾害应对?
ChatGPT是一个文本生成模型,它可以用于各种任务,但在处理紧急情况和灾害应对方面,它有一些潜在的用途和限制。在这篇文章中,我们将讨论ChatGPT在紧急情况和灾害应对中的应用,以及如何充分利用这一技术,并提…...

ElementUI浅尝辄止37:Select 选择器
当选项过多时,使用下拉菜单展示并选择内容。 1.如何使用?基础单选 v-model的值为当前被选中的el-option的 value 属性值 <template><el-select v-model"value" placeholder"请选择"><el-optionv-for"item in …...

PCL 基于任意四点计算球心坐标
文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 继续基于之前的思路PCL 基于三个点计算圆心坐标之二(二维),假设存在四个不共面的点, ( x 1 , y 1 ) (x_1,y_1)...

飞书即时消息无需API开发连接Cohere,打造飞书AI智能问答助手
飞书即时消息用户使用场景: 许多企业都在使用飞书系统进行协同办公,而现在有了Cohere大语言模型技术,能够根据用户的提问来自动产生回答,无需人为干预。对于企业负责人来说,他们认为如果将Cohere技术融入到飞书机器人中…...

FPGA实现Cordic算法——向量模式
FPGA实现Cordic算法——向量模式 FPGA实现Cordic算法——向量模式1.cordic算法基本原理2.FPGA实现cordic算法向量模式i、FPGA串行实现cordicii、FPGA流水线实现cordiciii、实验结果 FPGA实现Cordic算法——向量模式 1.cordic算法基本原理 FPGA中运算三角函数,浮点数…...

【常用代码14】el-input输入框内判断正则,只能输入数字,过滤汉字+字母。
问题描述: el-input输入框,只能输入数字,但是不能显示输入框最右边的上下箭头, <el-input v-model"input" type"number" placeholder"请输入内容" style"width: 200px;margin: 50px 0;&…...

[NLP]LLM--使用LLama2进行离线推理
一 模型下载 二 模型推理 本文基于Chinese-LLaMA-Alpaca-2项目代码介绍,使用原生的llama2-hf 克隆好了Chinese-LLaMA-Alpaca-2 项目之后,基于GPU的部署非常简单。下载完成以后的模型参数(Hugging Face 格式)如下: 简单说明一下各个文件的作…...

初始化一个Gin框架的Go-Web项目
使用到的第三方库 gin Gin 框架viper 配置文件管理cors 跨域资源请求配置gorm ORM 库zap 日志记录 main 包 Go 语言程序的入口点 main.go 文件 使用 flag 读取配置文件路径参数,默认当前目录下使用 viper 读取 config.ini 配置文件初始化初始数据初始化随机数种子初…...

Mybatis日期检索格式报错
问题复现 org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException: ### Error querying database. Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String ##…...

如何把Android Framework学彻底?一条龙学习
Framework通俗易懂 平时学习 Android 开发的第一步就是去学习各种各样的 API,如 Activity,Service,Notification 等。其实这些都是 Framework 提供给我们的。Framework 层为开发应用程序提供了非常多的API,我们通过调用这些 API …...

uview indexList 按字母跳转不了
点击字母跳转不到位的问题:在<u-index-list>添加方法select“clickSelect“ 锚点要加id,用对应的字母做为id值, <u-index-anchor :id"key" :index"key"/> <template><view><view class&qu…...

安全模型中的4个P
引言:在安全模型中,经常会碰到PDR,PPDR,IPDRR,CARTA-PPDR等模型,其中的P,是predict?是prevent?还是protect?还是policy呢? 一、4P字典意思解释 1、predict&a…...

网站优化搜索引擎与关键词
网站优化搜索引擎与关键词 人们不应该高估搜索引擎的智商。这不利于seo的研究,事实上,搜索引擎是非常愚蠢的,让我们举一个非常简单的例子,你在搜索引擎中输入“教师”这个词,搜索引擎就会给出一个准确的搜索列表。我们…...

aws-msk-托管kafka集群的简单使用(VPC内部访问:无验证和SASL认证)
1.使用控制台创建即可 根据实例类型创建需要至少15分以上,可以提前创建好ec2实例和Secrets Manager,一会会使用到 2. 创建Secrets Manager (使用无认证时请跳过) 官方文档:https://docs.aws.amazon.com/zh_cn/msk/latest/deve…...

Unity UGUI(二)核心组件
Unity Canvas相关知识学习 文章目录 Unity Canvas相关知识学习1. Canvas:1.1 Render Mode1.2 多个Canvas的显示顺序 2.Canvas Scaler:屏幕分辨率自适应2.1 UI Scale Mode 3. EventSystem4. Standalone Input Module5. Graphic Raycaster:图形…...

代码随想录二刷第二天(Python)
27. 移除元素 题目链接:https://leetcode.cn/problems/remove-element/ 题目描述:给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。不要使用额外的数组空间,你必…...

Mybatis学习笔记1 Mybatis入门
差不多根据mybatis中文文档:创建第一个mybatismaven项目,将它跑起来 入门_MyBatis中文网 新建库 建表 创建项目 重启之后 配置下Maven与encoding 成习惯了 新建模块 注意:这个GroupId和ArtifactId version是之后,你用Maven install时候后存放的包路径和包名 目录结构:虽然换…...

Spark 管理和更新Hadoop token 流程
Hadoop Token 管理 AM 通过 kerberos authenticationAM 获取 Yarn 和 HDFS TokenAM send tokens to containersContainers load tokens Enable debug message log4j.logger.org.apache.hadoop.securityDEBUG AM Generate tokens Logs: 23/09/07 22:38:50,375 INFO [main]…...

Android文件关联
用户需求:Android在系统文件夹找到一个文件想发送自己开发的app进行处理该怎么办? 这时候可以采用两个Activity,一个Activity用作Launcher,一个用于处理发送的文件;具体Activity intent-filter该怎么写了?可以参考下面的代码: <intent-filter><action androi…...

java操作adb查看apk安装包包名【搬代码】
Testpublic static void findadb() throws InterruptedException {String apkip"E:\\需求\\2023\\gql_1.0.1.apk";String findname1"cmd /c cd E:\\appium\\android-sdk\\build-tools\\27.0.2";//没有进到这里String s1 Cmd.exeCmd(findname1);System.out…...

【JAVA】Object类与抽象类
作者主页:paper jie_的博客 本文作者:大家好,我是paper jie,感谢你阅读本文,欢迎一建三连哦。 本文录入于《JAVASE语法系列》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和…...

【设计模式】二、UML 类图概述
文章目录 常见含义含义依赖关系(Dependence)泛化关系(Generalization)实现关系(Implementation)关联关系(Association)聚合关系(Aggregation)组合关系&#x…...