MongoDB自学笔记(四)

news2025/1/10 10:24:20

一、前文回顾

上一篇文章中我们学习了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.coloradmin.cn/o/1940089.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

OpenCV 像素操作—证件照换底色详细原理 C++纯手写实现

文章目录 总体步骤1.RGB转HSV2.找出要换的底色3.取反&#xff0c;黑白颠倒4.将原图像的非背景部分复制到新背景上 完整代码1.C纯手写版2.官方API版本 总体步骤 1.RGB转HSV 为什么一定要转为HSV 颜色空间&#xff1f; 将图像从BGR颜色空间转换为HSV颜色空间是因为HSV颜色空间更…

vscode 文件颜色变绿色

解决&#xff1a;关闭git功能 在设置中搜索Git:Enabled&#xff0c;取消Decorations: Enabled的勾选

内网渗透隧道构建,使用github项目联动msf绕uac,使用简单的spp来进行操作icmp隧道

在我们需要木马上线的时候&#xff0c;发现上线不了&#xff0c;我们一般就想到建立隧道&#xff0c;来解决问题&#xff0c;或者是说我们直接还一种连接的操作来进行上线。比如说我们正向连接上不了&#xff0c;我们可以还成反向连接的操作。或者我们使用隧道直接硬刚waf来进行…

计算机毕业设计-程序论文文档-基于SSM的驾校管理系统

本系统开发采用技术为JSP、Bootstrap、Ajax、SSM、Java、Tomcat、Maven 此文章为本人亲自指导加编写&#xff0c;禁止任何人抄袭以及各类盈利性传播&#xff0c; 相关的代码部署论文ppt代码讲解答辩指导文件都有可私要 项目源码&#xff0c;请关注❥点赞收藏并私信博主&#x…

代码随想录 day 18 二叉树

第六章 二叉树part06 详细布置 530.二叉搜索树的最小绝对差 需要领悟一下二叉树遍历上双指针操作&#xff0c;优先掌握递归 题目链接/文章讲解&#xff1a;https://programmercarl.com/0530.%E4%BA%8C%E5%8F%89%E6%90%9C%E7%B4%A2%E6%A0%91%E7%9A%84%E6%9C%80%E5%B0%8F%E7%B…

鸿蒙OpenHarmony Native API【HiLog】

HiLog Overview Description: HiLog模块实现日志打印功能。 开发者可以通过使用这些接口实现日志相关功能&#xff0c;输出日志时可以指定日志类型、所属业务领域、日志TAG标识、日志级别等。 syscap SystemCapability.HiviewDFX.HiLog Since: 8 Summary Files File …

甄选范文“论企业集成平台的理解与应用”,软考高级论文,系统架构设计师论文

论文真题 企业集成平台(Enterprise Imtcgation Plaform,EIP)是支特企业信息集成的像环境,其主要功能是为企业中的数据、系统和应用等多种对象的协同行提供各种公共服务及运行时的支撑环境。企业集成平台能够根据业务模型的变化快速地进行信息系统的配置和调整,保证不同系统…

HarmonyOS应用开发者高级认证,Next版本发布后最新题库 - 单选题序号3

基础认证题库请移步&#xff1a;HarmonyOS应用开发者基础认证题库 注&#xff1a;有读者反馈&#xff0c;题库的代码块比较多&#xff0c;打开文章时会卡死。所以笔者将题库拆分&#xff0c;单选题20个为一组&#xff0c;多选题10个为一组&#xff0c;题库目录如下&#xff0c;…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 堆内存申请(100分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 💻 ACM银牌🥈| 多次AK大厂笔试 | 编程一对一辅导 👏 感谢大家的订阅➕ 和 喜欢💗 🍿 最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,支持题目在线…

爬虫自己做的

1.urllib 1.1基本使用 1.2 下载&#xff08;图片&#xff0c;页面&#xff0c;视频&#xff09; 1.3 get 1.3.1 quote 中文变成对应uncode编码 当url 的wd中文时 quote是将中文变成对应uncode编码 然后拼接成完整的url 1.3.2urlencode方法 wd有多个参数 1.3.3ajas get实例 …

科普文:银行信贷系统概叙

信贷业务流程 资金需求者提交申请&#xff1a;资金需求者通过不同渠道&#xff08;如APP、网站、门店等&#xff09;提交贷款申请。 系统交互完成审批&#xff1a;系统通过自动化和人工相结合的方式&#xff0c;对贷款申请进行初步筛选和审批。 系统交互完成策略判断&#xf…

java学习---小项目---租房系统

package com.project.House_rental.HouseApp;import com.project.House_rental.HouseView.HouseView; //主界面 public class HouseApp {public static void main(String[] args) {new HouseView().List_();System.out.println("------已退出----------");} }package…

5G网络近海覆盖和融合应用5G网关5G路由器CPE

5G移动超远高速率CPE 5G移动超远距离高速率海上CPE是根据海上特殊场景需求&#xff0c;研发的5G天通电话&#xff0c;短信&#xff0c;北斗短报文&#xff0c;远航道宽带接入系统&#xff0c;专门为海洋急救&#xff0c;海洋作业、海洋施工定制的船用5G高速上网终端&#xff0c…

合并区间 1

合并区间 思路&#xff1a; 感觉就是一个个vector遍历&#xff1f; 两两对比。若第一个的第二个元素大于下一个的第一个元素&#xff0c;则合并&#xff0c;存入答案数组即可。 nonono 新思路 思路打开&#xff01; 对于每一个区间&#xff0c;判断他能覆盖的最大区间在哪里…

哈希 -- 简单实现

在STL库中&#xff0c;有map和set两个关联式容器&#xff0c;这两个容器的底层都是以红黑树为底层。但是在后续的发展过程中&#xff0c;我们发现有些场景的数据不适合用红黑树进行存储&#xff0c;所以有人就发明了底层为哈希表的map和set,称为unordered_map 和 unordered_set…

SAP Fiori 实战课程(二):新建页面

课程回顾 上一课中,利用Visual studio Code 新建、并运行了一个Demo工程。可以实现对项目的启动,启动后进入一个List清单。 那么本次课程的目前就是在上一节Demo的基础上,从零开始新建一个完整的页面。实现从首页清单,选择行后,鼠标点击,进入下一个页面。 准备工作 在开…

pcie数据传输

一 数据传输通道总体设计 在上传数据时首先将 FPGA 中数据缓存到 DDR3 存储器&#xff0c;然后上位机请求后把数据从DDR3 存储器中取出并通过 PCIE 总线将数据传输到上位机&#xff1b;在下传数据时上位机中的数据首先通过 PCIE 总线下传至 FPGA&#xff0c;FPGA 读取这些数据并…

展厅中控系统有哪些优势呢

格芬科技的展厅中控系统具有多方面的优势&#xff0c;主要体现在以下几个方面&#xff1a; 一、高度集成与灵活控制 全终端网络可编程&#xff1a;格芬科技的展厅中控系统采用全终端网络可编程技术&#xff0c;能够实现对展厅内各种设备的集中控制和管理&#xff0c;包括电脑…

关于对CSDN的谴责

关于对CSDN的谴责 如果不是心血来潮登了一次旧帐号我是万万不会想到&#xff0c;所有的文章都被设置成了仅VIP可见。 CSDN你的VIP有多不受人待见您不知道吗&#xff1f;为什么要把我用于你开通VIP刷绩效的工具&#xff1f; 这种东西不应该首先经过同意再开启吗&#xff1f;默认…

yum不可用

当使用yum命令安装xx时&#xff0c;出现“Cannot find a vaild baseurl for repo&#xff1a;base”的错误&#xff0c;通常意为着yum源配置不正确或网络连接问题。 一、普通方法 1、检查网络连接 使用ping命令&#xff0c;测试是否可以ping通公网&#xff0c;如百度&#xf…