$bitsAllSet

在本页面

  • $bitsAllSet
    • 3.2 版中的新功能。

$bitsAllSet匹配在field中设置了查询给出的所有位位置(即1)的文档。

{ <field>: { $bitsAllSet: <numeric bitmask> } }
{ <field>: { $bitsAllSet: < BinData bitmask> } }
{ <field>: { $bitsAllSet: [ <position1>, <position2>, ... ] } }

field值必须是数字实例或BinData实例。否则,$bitsAllSet将与当前文档不匹配。

  • Numeric Bitmask

    • 您可以提供一个数字位掩码以与操作数字段匹配。它必须可表示为非负的 32 位带符号整数。否则,$bitsAllSet将返回错误。

    • BinData Bitmask

      • 您还可以使用任意大的BinData实例作为位掩码。
    • Position List

      • 如果查询位位置列表,则每个<position>必须为非负整数。位位置从最低有效位0开始。例如,十进制数254将具有以下位位置:
Bit Value11111110
Position76543210

Behavior

Indexes

查询不能将索引用于查询的$bitsAllSet部分,尽管查询的其他部分也可以使用索引(如果适用)。

浮点值

$bitsAllSet将与不能表示为带符号的 64 位整数的数值不匹配。如果值太大或太小而无法容纳带符号的 64 位整数,或者具有小数部分,则可能是这种情况。

Sign Extension

数字以符号扩展。例如,$bitsAllSet认为将位置200设置为负数-5,但将比特位置200清除为正数+5

相反,BinData个实例是零扩展的。例如,给定以下文档:

db.collection.save({ x: BinData(0, "ww=="), binaryValueofA: "11000011" })

$bitsAllSet会将x以外的所有位清除。

Examples

以下示例将使用具有以下文档的集合:

db.collection.save({ _id: 1, a: 54, binaryValueofA: "00110110" })
db.collection.save({ _id: 2, a: 20, binaryValueofA: "00010100" })
db.collection.save({ _id: 3, a: 20.0, binaryValueofA: "00010100" })
db.collection.save({ _id: 4, a: BinData(0, "Zg=="), binaryValueofA: "01100110" })

位位置数组

以下查询使用$bitsAllSet运算符测试字段a是否在位置1和位置5上设置了位,其中最低有效位是在位置0上。

db.collection.find( { a: { $bitsAllSet: [ 1, 5 ] } } )

该查询与以下文档匹配:

{ "_id" : 1, "a" : 54, "binaryValueofA" : "00110110" }
{ "_id" : 4, "a" : BinData(0,"Zg=="), "binaryValueofA" : "01100110" }

Integer Bitmask

以下查询使用$bitsAllSet运算符测试字段a是否在位置145处设置了位(位掩码50的二进制表示是00110010)。

db.collection.find( { a: { $bitsAllSet: 50 } } )

该查询与以下文档匹配:

{ "_id" : 1, "a" : 54, "binaryValueofA" : "00110110" }

BinData Bitmask

以下查询使用$bitsAllSet运算符来测试字段a是否在位置 4 和 5 处设置了位(BinData(0, "MC==")的二进制表示形式是00110000)。

db.collection.find( { a: { $bitsAllSet: BinData(0, "MC==") } } )

该查询与以下文档匹配:

{ _id: 1, a: 54, binaryValueofA: "00110110" }