Mongodb删除操作中字符序对结果的影响

本文还是要从删除操作的语法说起。

db.collection.deleteMany(<filter>,{writeConcern: <document>,collation: <document>,hint: <document|string>}
)

删除语法中,可以指定数据写入策略,字符序和使用的索引字段。

字符序,引发了一些思考。记得在研究视图的时候,使用到了字符序。当时构建了下面的集合

db.places.insertMany([{ _id: 1, category: "café", status: "A" },{ _id: 2, category: "cafe", status: "a" },{ _id: 3, category: "cafE", status: "a" }])

当指定使用法语字符序时,在构建的视图中计算返回文档时结果时3

db.placesView.countDocuments({ category: "cafe"})

构建视图和介绍可参考前面的视图介绍文章Mongodb创建和查询视图(二)。

既然使用查询条件{ category: "cafe"}返回3个结果,那在deleteOne(), deleteMany()方法中指定字符序,会删除多少条数据,删除1条,还是3条。很有意思和值得探讨的问题。

首先执行deleteOne(),看到只删除了一条数据。按照数据库插入顺序,删除了最早插入数据库的数据。在insertMany()方法中,默认按照数组中的排列顺序插入数据,所以会删除_id为1的数据。

db.places.deleteOne({category: "cafe"}, {collation: { locale: "fr", strength: 1 } }){"acknowledged" : true,"deletedCount" : 1
}

查询结果集,只有_id为2和3的数据了。

这里可以得出结论,使用deleteOne, 无论是否指定字符序,都只删除一条数据。

接下来,重新构建集合,来测试deleteMany()方法。

db.places.drop()
db.places.insertMany([{ _id: 1, category: "café", status: "A" },{ _id: 2, category: "cafe", status: "a" },{ _id: 3, category: "cafE", status: "a" }])

首先执行deleteMany()方法,不带有collation,只能够删除满足查询条件的数据,删除了_id为2的数据。

db.places.deleteMany({category: "cafe"})
{"acknowledged" : true,"deletedCount" : 1
}

使用find查询,能够查出其他两条数据

再次重新构建集合

db.places.drop()
db.places.insertMany([{ _id: 1, category: "café", status: "A" },{ _id: 2, category: "cafe", status: "a" },{ _id: 3, category: "cafE", status: "a" }])

这次执行带有collation的deleteMany()方法。返回结果中,删除了3条数据。

db.places.deleteMany({category: "cafe"}, {collation: { locale: "fr", strength: 1 } })
{"acknowledged" : true,"deletedCount" : 3
}

由此可见,当指定字符序collation时,字符序的引入,对删除数据的结果产生了影响。

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

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

相关文章

MySQL第四战:视图以及常见面试题(上)

目录 目录&#xff1a; 一.视图 1.介绍什么是视图 2.视图的语法 语法讲解 实例操作 二.MySQL面试题 1.SQL脚本 2.面试题实战 三.思维导图 目录&#xff1a; 随着数字化时代的飞速发展&#xff0c;数据库技术&#xff0c;特别是MySQL&#xff0c;已经成为IT领域中不可…

Mybatis简易搭建并查询数据库表内所有数据

搭建步骤 1.在mysql中创建user表&#xff0c;添加数据2.创建maven模块&#xff0c;导入坐标3.在资源文件夹中导入需要用到的logback.xml4.编写MyBatis 核心配置文件->替换连接信息 解决硬编码问题5.编写 SQL映射文件->统一管理sgl语句&#xff0c;解决硬编码问题6.编码定…

HackTheBox - Medium - Linux - Ambassador

Ambassador Ambassador 是一台中等难度的 Linux 机器&#xff0c;用于解决硬编码的明文凭据留在旧版本代码中的问题。首先&#xff0c;“Grafana”CVE &#xff08;“CVE-2021-43798”&#xff09; 用于读取目标上的任意文件。在研究了服务的常见配置方式后&#xff0c;将在其…

【管理篇 / 登录】❀ 06. macOS下使用USB配置线登录 ❀ FortiGate 防火墙

【简介】飞塔防火墙上都会配有CONSOLE接口&#xff0c;包装里都会配置一根USB配置线&#xff0c;通过这个接口和这根线&#xff0c;我们可以用命令的方式登录飞塔防火墙。随着苹果电脑的普及&#xff0c;我们来学习如何在macOS中使用USB配置线登录飞塔防火墙。 早期飞塔防火墙包…

useContext

可以跨组件传值 其实主要的就是三步 1、const xxx React.createContext();创建一个context 2、<xxx.Provider value{{ num, setNum }}>父组件设置要传递的值 3、const { num, setNum } React.useContext(xxx);子组件下使用 特点&#xff1a; 1、可以有多个xxx.Pr…

网络优化篇(一)---------TCP重传性能优化

本文通过一个TCP重传优化的实际问题,详细讲解问题的分析、定位、优化过程。 通过本文你将学到: 如何通过linux命令和/proc文件系统分析TCP性能数据如何通过linux命令和netlink api分析某个具体的TCP连接的性能数据如何通过bcc工具分析TCP性能数据如何通过调整系统参数优化TCP重…

第 121 场 LeetCode 双周赛题解

A 大于等于顺序前缀和的最小缺失整数 模拟&#xff1a;先求最长顺序前缀的和 s s s &#xff0c;然后从 s s s 开始找没有出现在 n u m s nums nums 中的最小整数 class Solution { public:int missingInteger(vector<int> &nums) {unordered_set<int> vis(…

[C#]使用DlibDotNet人脸检测人脸68特征点识别人脸5特征点识别人脸对齐人脸比对FaceMesh

【官方框架地址】 https://github.com/takuya-takeuchi/DlibDotNet 【算法介绍】 DlibDotNet是一个开源的.NET库&#xff0c;用于实现机器学习和计算机视觉应用。它基于C库dlib&#xff0c;通过C/CLI封装了dlib的所有功能&#xff0c;为.NET开发者提供了简单易用的API。以下是…

蓝桥杯练习题(一)

&#x1f4d1;前言 本文主要是【算法】——蓝桥杯练习题&#xff08;一&#xff09;的文章&#xff0c;如果有什么需要改进的地方还请大佬指出⛺️ &#x1f3ac;作者简介&#xff1a;大家好&#xff0c;我是听风与他&#x1f947; ☁️博客首页&#xff1a;CSDN主页听风与他 …

【计算机毕业设计】SSM健身房管理系统

项目介绍 本项目为后台管理系统&#xff0c;主要分为管理员与用户两种角色&#xff1b; 登录页面,管理员首页,会员增删改查,教练增删改查,运动器材管理等功能。 用户角色包含以下功能&#xff1a; 用户登录页面,用户首页,选择课程,选择教练等功能。 环境需要 1.运行环境&a…

LabVIEW在指针式仪表读数中的应用

在LabVIEW环境中&#xff0c;为实现指针式仪表的自动读数&#xff0c;首先进行图像预处理&#xff0c;包括图像缩放、灰度化和二值化&#xff0c;以提高处理速度和减少噪声干扰。利用LabVIEW的图像处理功能&#xff0c;灰度化和二值化操作简化了图像的色彩信息&#xff0c;便于…

Linux Shell数学运算与条件测试

一、Shell数学运算 1.Shell常见的算术运算符号 序号算术运算符号意义1、-、*、/、%加、减、乘、除、取余2**幂运算3、–自增或自减4&&、||、&#xff01;与、或、非5、!相等、不相等&#xff0c;也可写成6、、-、*、/、%赋值运算符&#xff0c;a1相等于aa1 2.Shell常…