On this page
$bitsAllClear
在本页面
$bitsAllClear
- 3.2 版中的新功能。
$bitsAllClear匹配field
中查询给出的所有位位置*(即0
)都是清除的文档。
{ <field>: { $bitsAllClear: <numeric bitmask> } } |
{ <field>: { $bitsAllClear: < BinData bitmask> } } |
{ <field>: { $bitsAllClear: [ <position1>, <position2>, ... ] } } |
field
值必须是数字实例或BinData实例。否则,$bitsAllClear将与当前文档不匹配。
Numeric Bitmask
您可以提供一个数字位掩码以与操作数字段匹配。它必须可表示为非负的 32 位带符号整数。否则,$bitsAllClear将返回错误。
BinData Bitmask
- 您还可以使用任意大的BinData实例作为位掩码。
Position List
- 如果查询位位置列表,则每个
<position>
必须为非负整数。位位置从最低有效位0
开始。例如,十进制数254
将具有以下位位置:
- 如果查询位位置列表,则每个
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
是否在位置0
,1
和5
(位掩码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" }