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
  }
相关推荐
小嵌同学7 小时前
Linux:malloc背后的实现细节
大数据·linux·数据库
R瑾安7 小时前
mysql安装(压缩包方式8.0及以上)
数据库·mysql
代码的余温8 小时前
MySQL Cluster核心优缺点
数据库·mysql
Mr.Entropy9 小时前
请求超过Spring线程池的最大线程(处理逻辑)
数据库·sql·spring
GBASE9 小时前
“G”术时刻:南大通用GBase 8c数据库权限管理场景实践(二)
数据库
易白10 小时前
MongoDB服务1053错误、1067错误处理
mongodb
wearegogog12310 小时前
MySQL中实施排序(sorting)及分组(grouping)操作
数据库·mysql
2301_8035545210 小时前
MySQL 主从读写分离架构
数据库·mysql·架构
正在走向自律10 小时前
Ubuntu系统下Python连接国产KingbaseES数据库实现增删改查
开发语言·数据库·python·ubuntu·kingbasees·ksycopg2
没有bug.的程序员10 小时前
Redis vs Memcached vs MongoDB:深入对比与选型指南
java·redis·mongodb·memcached