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" }