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") }
  ]
相关推荐
秦苒&几秒前
【脉脉】AI 创作者 xAMA 知无不言:在浪潮里,做会发光的造浪者
大数据·c语言·数据库·c++·人工智能·ai·操作系统
码农水水3 分钟前
美团Java面试被问:Netty的ByteBuf引用计数和内存释放
java·开发语言·数据库·mysql·算法·面试·职场和发展
码农水水5 分钟前
浅谈 MySQL InnoDB 的内存组件
java·开发语言·数据库·后端·mysql·面试
shjita5 分钟前
mapreduce输出乱码的处理
java·开发语言·数据库
qq_1927798710 分钟前
将Python Web应用部署到服务器(Docker + Nginx)
jvm·数据库·python
he___H12 分钟前
MySQL调优-----MySQL执行原理
数据库·mysql
刃神太酷啦19 分钟前
Linux 基础 IO 收官:库的构建与使用、进程地址空间及核心知识点全解----《Hello Linux!》(11)
java·linux·c语言·数据库·c++·算法·php
倔强的石头10623 分钟前
多模融合重塑文档数据库:金仓数据库 MongoDB 兼容版的技术实践
数据库·mongodb·kingbase
Knight_AL25 分钟前
掌握 SQL 窗口函数:分组、排名与最新记录获取的最佳实践
数据库·sql·mysql·oracle
Coder_Boy_33 分钟前
基于SpringAI的在线考试系统-数据库设计核心业务方案(微调)
java·数据库·人工智能·spring boot·领域驱动