MongoDB聚合运算符:$bitAnd

文章目录

$bitAnd集合运算符返回对intlong数组进行位操作和运算的结果。

语法

js 复制代码
{ $bitAnd: { [ <expression1>, <expression2>, ... ] }

用法

  • 如果操作数包括整型和长整型值,MongoDB会对计算出的整数结果进行符号扩展,并返回长整型值,否则返回相应值类型的结果。
  • 如果参数数组元素是不同的数据类型,比如:字符串、双精度数或小数,将返回错误。
  • 如果参数是空数组,则返回NumberInt(-1)
  • 如果任何操作数为null,则返回null

**注意:**使用mongosh时,所有的数值都是双精度数double类型,没有整型,在mongosh中要使用整型,必须要使用NumberInt()NumberLong()进行强制类型转换,切记切记!

举例

使用下面的命令创建switches集合:

js 复制代码
db.switches.insertMany( [
    { _id: 0, a: NumberInt(0), b: NumberInt(127) },
    { _id: 1, a: NumberInt(2), b: NumberInt(3) },
    { _id: 2, a: NumberInt(3), b: NumberInt(5) }
] )

两个整数按位进行与操作

下面的聚合在$project阶段使用$bitAnd对字段ab进行与操作:

js 复制代码
db.switches.aggregate( [
  {
    $project: {
      result: {
        $bitAnd: [ "$a", "$b" ]
      }
    }
  }
])

返回的结果如下:

json 复制代码
  [
    { "_id": 0, "result": 0 }
    { "_id": 1, "result": 2 }
    { "_id": 2, "result": 1 }
  ]

长整数和整数按位与操作

下面的聚合在$project阶段使用$bitAnd对整型字段a和转换为长整型的字段b进行与操作:

js 复制代码
db.switches.aggregate( [
  {
    $project: {
      result: {
        $bitAnd: [ "$a", NumberLong("63") ]
      }
    }
  }
])

操作返回下面的结果:

json 复制代码
  [
    { "_id": 0, "result": Long("0") }
    { "_id": 1, "result": Long("2") }
    { "_id": 2, "result": Long("3") }
  ]
相关推荐
m***56721 小时前
Win10下安装 Redis
数据库·redis·缓存
Warren981 小时前
Python自动化测试全栈面试
服务器·网络·数据库·mysql·ubuntu·面试·职场和发展
kka杰3 小时前
MYSQL 表的增删查改-更新/删除
数据库·mysql
q***44813 小时前
mysql配置环境变量——(‘mysql‘ 不是内部或外部命令,也不是可运行的程序 或批处理文件解决办法)
数据库·mysql·adb
风123456789~4 小时前
【OceanBase专栏】OB租户-创建实验
数据库·笔记·oceanbase
cmcm!4 小时前
学习笔记1
数据库·笔记·学习
Zero-Talent4 小时前
MySQL初级
数据库·mysql·oracle
烟雨归来4 小时前
oracle数据文件大小异常故障处理
数据库·oracle
jenchoi4134 小时前
【2025-11-23】软件供应链安全日报:最新漏洞预警与投毒预警情报汇总
网络·数据库·安全·web安全·网络安全
auspicious航4 小时前
PostgreSQL数据库之使用 pg_waldump 和 pg_walinspect 查看 WAL 文件的内容
数据库·postgresql