Mongodb在UPDATE中使用二进制运算更新字段

学习mongodb,体会mongodb的每一个使用细节,欢迎阅读威赞的文章。这是威赞发布的第75篇mongodb技术文章,欢迎浏览本专栏威赞发布的其他文章。如果您认为我的文章对您有帮助或者解决您的问题,欢迎在文章下面点个赞,或者关注威赞。谢谢。

Mongodb的UPDATE提供了各种各样的方法,包括字段数值增加,数组更新等。本文介绍Mongodb使用$bit方法更新字段。

定义

bit操作符,对指定字段进行二进制更新。该操作符支持二进制与运算,或运算和异或运算。按照下面的形式,使用bit操作符。

复制代码
{ $bit: {<field>: { <and|or|xor>: <int>}}}

$bit操作符,只能应用在整型数值类型字段的更新。更新嵌入式文档或嵌入式数组是,需要使用点操作符。

行为

  • 自mongodb5.0开始,UPDATE操作按照字段名称的字典顺序更新字段。当字段中包含数字时,按照数字顺序依次更新字段。当然,对一个文档的多个字段操作,是原子性的。
  • mongodb 5.0版本以后,向$bit传入空表达式({ })时,mongodb不再抛出错误。空表达式不会修改字段值 ,也不会在oplog中,添加新的操作记录。

应用

构建集合switches并插入数据,其中expdata字段,是整型数字类型的字段

复制代码
db.switches.insertMany([{
    _id: 1,expdata: Int32(13)
},{
    _id: 2,expdata: Int32(3)
},{
    _id: 3,expdata: Int32(1)
}])

与运算

构建数据更新语句,对expdata进行二进制更新。

复制代码
db.switches.updateOne({_id: 1}, {$bit: {expdata: {and: Int32(10)}}})

查看更新结果

复制代码
db.switches.find()
{
    "_id": 1,
    "expdata": 8
  }

或运算

构建数据更新语句,使用或运算更新文档。

复制代码
db.switches.updateOne({_id: 2}, {$bit: {expdata: {or: Int32(5)}}})

查看更新结果

复制代码
{
    "_id": 2,
    "expdata": 7
  }

异或运算

构建数据更新语句,使用或运算更新文档。

复制代码
db.switches.updateOne({_id: 3}, {$bit: {expdata: {xor: Int32(5)}}})

查看更新结果

复制代码
{
    "_id": 3,
    "expdata": 4
  }
相关推荐
咖啡Beans16 分钟前
MySQL中使用@符号定义用户变量
数据库·mysql
GreatSQL4 小时前
MySQL迁移至GreatSQL后,timestamp字段插入报错解析
数据库
expect7g5 小时前
COW、MOR、MOW
大数据·数据库·后端
DemonAvenger6 小时前
MySQL海量数据快速导入导出技巧:从实战到优化
数据库·mysql·性能优化
薛定谔的算法1 天前
phoneGPT:构建专业领域的检索增强型智能问答系统
前端·数据库·后端
Databend1 天前
Databend 亮相 RustChinaConf 2025,分享基于 Rust 构建商业化数仓平台的探索
数据库
得物技术1 天前
破解gh-ost变更导致MySQL表膨胀之谜|得物技术
数据库·后端·mysql
似水流年流不尽思念1 天前
MongoDB 有哪些索引?适用场景?
后端·mongodb
Raymond运维1 天前
MariaDB源码编译安装(二)
运维·数据库·mariadb
沢田纲吉1 天前
🗄️ MySQL 表操作全面指南
数据库·后端·mysql