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") }
  ]
相关推荐
敢敢のwings27 分钟前
C++信号与槽机制自实现
开发语言·数据库·c++
杭州杭州杭州2 小时前
MySQL超全笔记
数据库·笔记·mysql
OpenVINO生态社区3 小时前
【汽车功能安全:软件与硬件缺一不可】
数据库·安全·汽车
程序猿阿伟5 小时前
《打破SQL与AI框架对接壁垒,解锁融合新路径》
数据库·人工智能·sql
点燃大海5 小时前
MySQL表结构导出(Excel)
java·数据库·python·mysql·spring
꧁坚持很酷꧂5 小时前
Qt远程连接数据库,注册,登录
开发语言·数据库·qt
加油,旭杏5 小时前
【Redis】服务端高并发分布式结构
数据库·redis·分布式
꧁༺朝花夕逝༻꧂6 小时前
MySQL--数据备份
数据库·mysql
共享家95278 小时前
Linux常用命令详解:从基础到进阶
linux·服务器·数据库
我是个假程序员12 小时前
sql server数据库可疑修复
数据库