MongoDB自学笔记(四)

一、前文回顾

上一篇文章中我们学习了MongoDB中的更新方法,也学了一部分操作符。今天我们将学习最后一个操作“删除”。

二、删除

原始数据如下:
image.png

1、deleteOne

语法:db.collection.deleteOne(< query >,< options >)
具体参数参考官网:
db.collection.deleteOne()
该命令会删除满足条件的第一个数据。
示例:例如我们想删除item = journal的数据

db.inventory.deleteOne({"item":"journal"})

image.png

2、deleteMany

语法:db.collection.deleteMany(< query >,< options >)
用法和上面基本一样,有所不同的是 deleteMany会删除所有满足条件的数据,这里不再赘述。

3、小结
至此我们已经把MongoDB的增删改查的基础学习完了,接下来要学习的则是更进阶的部分。我们知道在大多数场景下,数据库的作用是查询数据,所有我们先学习查询的进阶内容。

三、查询进阶—索引(初步介绍)

1、什么是索引

与绝大多数数据库一样,MongoDB也有索引。索引是一种加速查询的数据结构,通常是由B树或者B+树。例如我们现在有一个100万个集合的文档,我们要查找出其中name = “hardy”的数据,如果我们并没有在该字段中添加索引,那么MongoDB默认会使用全表扫描的方式来查询,如下图

如果没有索引,那么MongoDB只能从第一个文档开始 挨个的比较数据是否匹配,在数据量小的时候比较快,但是随着数据量的增大很明显速度会越来越慢。那么该如何优化呢?此时我们可以很容易的想到加索引。
索引可以简单理解为一个字典,他记录了某个值以及该值对应的文档在哪里,知道了具体的位置,那么查询就会变的相当迅速。

B+树的层级通常不高,而且采用的是二分查找法。可以很大程度上减少查询的次数,当找到对应索引之后,索引上会记录文档的ID,此时通过文档的ID再去查询文档,效率就会大大提供。

2、怎么创建索引

语法:db.collection.createIndex( < keys >, < options >, < commitQuorum >)
完整介绍
db.collection.createIndex()
示例:比如我要给集合inventory中的item字段添加索引

db.inventory.createIndex({"item": 1},{unique: true,name: "itemIndex"}
)这里的1表示升序,unique表示当前索引是唯一索引不能重复,而name是索引的名称

运行结果:
image.png
从结果中可以看出,之前存在一个索引,现在存在两个索引。那么问题来了,为什么一开始就存在一个索引呢?这个其实也很好理解,Mongo默认会给每个文档添加一个唯一的ID当作主键,所以这个一开就存在的是主键索引。接下来我们看下结果是否和我们预期的一样。这里我们使用getIndexes命令

db.inventory.getIndexes()

结果如下
image.png

3、怎么查看查询是否用了索引

和MySQL一样,MongoDB中也有explain函数,用于查看数据库的执行计划。这里我们用这个命令来判断当前的查询是否用了索引。

3.1、查询没有索引的字段

这里我们以status字段为例,我们要查询status=A的数据

db.inventory.explain().find({"status":"A"})

部分结果如下
image.png
winningPlan表示实际使用的查询计划,从这里不难看出针对当前查询,MongoDB采用的是COLLSCAN,集合扫描(也可以理解为全表扫描),需要每一个文档挨个的比较。

3.2、查询含有索引的列
db.inventory.explain().find({"item":"mat"})

部分结果如下
image.png
可以看到实际执行的计划是采用IXSCAN也就是索引扫描,于此同时上面的stage还有一个FETCH,这里的FETCH 也就是MySQL中的回表。因为当前的索引只记录了索引值以及当前索引对应的文档ID,MongoDB拿到当前文档的ID后还需要通过ID再次去查一次文档。聪明的你可能会问了,那有没有不用FECTH的情况呢?很显然是有的,比如我们只查询item字段,此时就不需要再次回表。代码如下

db.inventory.explain().find({"id":"mat"},{"item":1})

image.png

当然你可以直接通过ID查询,也是不会回表的。至于为什么个放到后文讲

db.inventory.explain().find({"_id":"66951edbdf24000083007d75"})

结果如下
image.png

四、结束语

本文讲简单的讲述了一下删除文档操作,以及对索引展开了一定的讲解,当然索引的内容远不止此,后面还有更多的内容,希望对你有所帮助。

未完待续

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/380958.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学生信息管理系统-可视化-科目管理CRUD代码生成器

学生管理系统中的科目管理是一个重要的组成部分&#xff0c;它负责维护和管理学校中所有的教学科目信息。 可视化快速界面生成CRUD界面&#xff0c;API通过代码生成器生成器生成。 新增数据库表 拷贝demo_table修改为clazz_kemu表 修改表结构 其中包括一个自增ID字段&#x…

在虚拟机 CentOS7 环境下安装 MySQL5.7 数据库

配置目标 在虚拟机的 Linux CentOS7 环境下安装 MySQL5.7 版数据库&#xff0c;并能从宿主机 Windows 系统连接该数据库&#xff08;默认端口&#xff1a;3306&#xff09;。 1. 准备工作 WMware 虚拟机&#xff1a;VMware Workstation 16 ProCentOS7 镜像&#xff1a;CentO…

Java面试题--JVM大厂篇之深入解析JVM中的Serial GC:工作原理与代际区别

目录 引言&#xff1a; 正文&#xff1a; 一、Serial GC工作原理 年轻代垃圾回收&#xff08;Minor GC&#xff09;&#xff1a; 老年代垃圾回收&#xff08;Major GC或Full GC&#xff09;&#xff1a; 二、年轻代和老年代的区别 年轻代&#xff08;Young Generation&a…

redis其他类型和配置文件

很多博客只讲了五大基本类型&#xff0c;确实&#xff0c;是最常用的&#xff0c;而且百分之九十的程序员对于Redis只限于了解String这种最常用的。但是我个人认为&#xff0c;既然Redis官方提供了其他的数据类型&#xff0c;肯定是有相应的考量的&#xff0c;在某些特殊的业务…

【C++】——new和delete

文章目录 热身试题C中的内存管理new与delete对于内置类型的操作new与delete对于自定义类型的操作 malloc/free和new/delete的区别 热身试题 int globalVar 1; static int staticGlobalVar 1; void Test() {static int staticVar 1;int localVar 1;int num1[10] { 1, 2, 3…

嵌入式物联网在教育行业的应用——案例分析

作者主页: 知孤云出岫 嵌入式物联网在教育行业的应用——案例分析 目录 作者主页:嵌入式物联网在教育行业的应用——案例分析一、引言二、智能教室&#xff1a;环境监测系统1. 硬件需求2. 电路连接3. 代码实现 三、个性化学习&#xff1a;智能学习平台1. 数据处理与分析2. 代…

Flutter中GetX的用法(超详细使用指南之路由依赖管理篇)

目录 1.前言 2.GetX 依赖管理概述 1.GetX 依赖管理的基本概念 2.与其他依赖管理工具的比较 3. 基础依赖注入 1.Get.put 2.Get.lazyPut 3.Get.putAsync 4.高级依赖注入 1.使用Get.create 2.依赖生命周期管理 5. 参考资料 1.前言 今天这篇博客主要介绍Getx的三大功能…

ESP8266模块(2)

实例1 查看附近的WiFi 步骤1&#xff1a;进入AT指令模式 使用USB转串口适配器将ESP8266模块连接到电脑。打开串口终端软件&#xff0c;并设置正确的串口和波特率&#xff08;通常为115200&#xff09;。输入以下命令并按回车确认&#xff1a; AT如果模块响应OK&#xff0c;…

R语言包AMORE安装报错问题以及RStudio与Rtools环境配置

在使用R语言进行AMORE安装时会遇到报错,这时候需要采用解决办法: AMORE包安装,需要离线官网下载安装包: Index of /src/contrib/Archive/AMORE (r-project.org)https://cran.r-project.org/src/contrib/Archive/AMORE/ 一、出现的问题 最近开始学习R语言,安装了最新版…

Window中 Redis下载安装

Redis7.2.3连接&#xff1a; 我用夸克网盘分享了「redis-windows-7.2.3.zip」&#xff0c;点击链接即可保存。打开「夸克APP」&#xff0c;无需下载在线播放视频&#xff0c;畅享原画5倍速&#xff0c;支持电视投屏。 链接&#xff1a;https://pan.quark.cn/s/4dfb0497707a 在安…

义务外贸wordpress独立站主题

健身器材wordpress网站模板 跑步机、椭圆机、划船机、动感单车、健身车、深蹲架、龙门架、健身器材wordpress网站模板。 https://www.jianzhanpress.com/?p4251 农业机械wordpress网站模板 植保机械、畜牧养殖机械、农机配件、土壤耕整机械、农业机械wordpress网站模板。 …

WebRTC音视频-前言介绍

目录 效果预期 1&#xff1a;WebRTC相关简介 1.1&#xff1a;WebRTC和RTC 1.2&#xff1a;WebRTC前景和应用 2&#xff1a;WebRTC通话原理 2.1&#xff1a;媒体协商 2.2&#xff1a;网络协商 2.3&#xff1a;信令服务器 效果预期 1&#xff1a;WebRTC相关简介 1.1&…

Windows FFmpeg 开发环境搭建

FFmpeg 开发环境搭建 FFmpeg命令行环境搭建使用FFmpeg官方编译的库Windows编译FFmpeg1. 下载[msys2](https://www.msys2.org/#installation)2. 安装完成之后,将安装⽬录下的msys2_shell.cmd中注释掉的 rem set3. 修改pacman 镜像源并安装依赖4. 下载并编译源码 FFmpeg命令行环境…

Python PDF Magic:合并和拆分随心所欲

大家好&#xff01;小编今天要为大家带来一篇关于Python操作PDF的秘籍——无论是要将PDF合并成一份整体&#xff0c;还是将一个庞大的PDF文件拆分成多个小伙伴&#xff0c;都轻松hold住&#xff01;你准备好了吗&#xff1f;让我们开始这场奇妙的PDF操作之旅吧&#xff01; 准…

C++基础入门(二)(函数重载,引用,内联函数,nullptr)

目录 一. 函数重载 1. 概念 2. 实现 (1). 参数类型不同 (2). 参数个数不同 (3). 参数类型顺序不同 3. 注意事项 (1). 返回值不能作为重载的条件 (2). 不能仅按函数返回类型重载 (3). 与缺省参数的问题 二. 引用 1. 概念和定义 2. 引用的特性 (1). 引用在定义时必须…

【多任务YOLO】 A-YOLOM: You Only Look at Once for Real-Time and Generic Multi-Task

You Only Look at Once for Real-Time and Generic Multi-Task 论文链接&#xff1a;http://arxiv.org/abs/2310.01641 代码链接&#xff1a;https://github.com/JiayuanWang-JW/YOLOv8-multi-task 一、摘要 高精度、轻量级和实时响应性是实现自动驾驶的三个基本要求。本研究…

HTML5实现好看的天气预报网站源码

文章目录 1.设计来源1.1 获取天气接口1.2 PC端页面设计1.3 手机端页面设计 2.效果和源码2.1 动态效果2.2 源代码 源码下载万套模板&#xff0c;程序开发&#xff0c;在线开发&#xff0c;在线沟通 作者&#xff1a;xcLeigh 文章地址&#xff1a;https://blog.csdn.net/weixin_4…

深入理解PHP基础【代码审计实战指南】

文章目录 基础语法单双引号的区别前后端分离数据类型PHP常量函数var_dump函数count函数print_r函数**readfile&#xff08;&#xff09;函数****file_get_contents()函数****file_put_contents()函数**header函数fopen函数fread 函数rename函数copy&#xff08;&#xff09;函数…

【Android】视图与常用控件总结

文章目录 一、视图基础1.1 设置视图的宽高1.2 设置视图的间距1.3 设置视图的对齐方式1.4 总结 二、控件2.1 TextView2.1.1 设置宽高2.1.2 设置内容2.1.3 设置大小2.1.4 设置颜色 2.2 Button2.3 EditText2.4 ImageView2.5 ProgressBar2.6 AlertDialog2.7 ProgressDialog 本文主要…

EVM-MLIR:以MLIR编写的EVM

1. 引言 EVM_MLIR&#xff1a; 以MLIR编写的EVM。 开源代码实现见&#xff1a; https://github.com/lambdaclass/evm_mlir&#xff08;Rust&#xff09; 为使用MLIR和LLVM&#xff0c;将EVM-bytecode&#xff0c;转换为&#xff0c;machine-bytecode。LambdaClass团队在2周…