$bitsAllClear

在本页面

$bitsAllClear匹配field中查询给出的所有位位置*(即0)都是清除的文档。

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

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

Bit Value 1 1 1 1 1 1 1 0
Position 7 6 5 4 3 2 1 0

Behavior

Indexes

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

浮点值

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

Sign Extension

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

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

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

$bitsAllClear会将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" })

位位置数组

以下查询使用$bitsAllClear运算符测试字段a是否在位置1和位置5处有位清零,其中最低有效位是位置0

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

该查询与以下文档匹配:

{ "_id" : 2, "a" : 20, "binaryValueofA" : "00010100" }
{ "_id" : 3, "a" : 20, "binaryValueofA" : "00010100" }

Integer Bitmask

以下查询使用$bitsAllClear运算符测试字段a是否在位置015(位掩码35的二进制表示为00100011)中具有清除的位。

db.collection.find( { a: { $bitsAllClear: 35 } } )

该查询与以下文档匹配:

{ "_id" : 2, "a" : 20, "binaryValueofA" : "00010100" }
{ "_id" : 3, "a" : 20, "binaryValueofA" : "00010100" }

BinData Bitmask

以下查询使用$bitsAllClear运算符测试字段a是否在位置 2 和 4 处具有清除的位(BinData(0, "ID==")的二进制表示形式是00010100

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

该查询与以下文档匹配:

{ "_id" : 2, "a" : 20, "binaryValueofA" : "00010100" }
{ "_id" : 3, "a" : 20, "binaryValueofA" : "00010100" }
首页