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") }
  ]
相关推荐
星星也在雾里6 小时前
PgBouncer 解决 PostgreSQL 连接数超限 + 可视化监控
数据库·postgresql
雨辰AI7 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
长城20248 小时前
关于MySql的ONLY_FULL_GROUP_BY问题
数据库·mysql·聚合列
常常有8 小时前
MySQL 底层执行原理:输入SQL语句到两阶段提交
数据库·sql·mysql
Mr. zhihao8 小时前
深入解析redis基本数据结构
数据结构·数据库·redis
m0_748839498 小时前
利用天正暖通CAD快速掌握风管数量统计的方法
数据库
随身数智备忘录8 小时前
什么是设备管理体系?设备管理体系包含哪些核心模块?
网络·数据库·人工智能
海市公约9 小时前
MySQL更新语句执行全流程:从Buffer Pool修改到二阶段提交
数据库·mysql·binlog·innodb·undo log·二阶段提交·update执行原理
颂love10 小时前
MySQL的执行流程
android·数据库·mysql
程序leo源10 小时前
Qt窗口详解
开发语言·数据库·c++·qt·青少年编程·c#