$bitsAnyClear
Nesta página
$bitsAnyClear
$bitsAnyClear
corresponde a documentos em que qualquer uma das posições de bit fornecidas pela query está limpa (ou seja,0
) emfield
.{ <field>: { $bitsAnyClear: <numeric bitmask> } }
{ <field>: { $bitsAnyClear: [ <position1>, <position2>, ... ] } }
O valor
field
deve ser numérico ou uma instânciaBinData
. Caso contrário, o$bitsAnyClear
não corresponderá ao documento atual.- Máscara de bits numérica
- Você pode fornecer uma máscara de bits numérica para comparação com o campo do operando. Ela deve ser um inteiro de 64 bits assinado não negativo. Caso contrário,
$bitsAnyClear
retornará um erro. - Máscara de bits BinData
- Você também pode usar uma instância de
BinData
arbitrariamente grande como uma máscara de bits. - Lista de posições
- Ao consultar uma lista de posições de bits, cada
<position>
deve ser um número inteiro não negativo. As posições dos bits começam em0
a partir do bit menos significativo. Por exemplo, o número decimal254
teria as seguintes posições de bits:
Valor de bits11111110Posição76543210
Comportamento
A endianidade do seu sistema depende da arquitetura da sua máquina. Os números nos dados BSON são sempre armazenados como little-endian, se o seu sistema for big-endian , isso significa que os dados numéricos são convertidos entre big e little endian.
No contexto dos operadores de expressão de correspondência de teste de bit:
BinData
Os valores atuam como bitmasks e são interpretados como se fossem números little-endian sem sinal de comprimento arbitrário. O byte endereçável mais baixo é sempre interpretado como o byte menos significativo. Da mesma forma, o byte endereçável de maior valor no BinData
é sempre interpretado como o byte mais significativo.
Indexes
As queries não podem usar índices para a parte $bitsAnyClear
de uma query, embora as outras partes de uma query possam usar índices, se aplicável.
Valores de ponto flutuante
$bitsAnyClear
não corresponderá a valores numéricos que não possam ser representados como um número inteiro de 64 bits assinado. Esse pode ser o caso se um valor for muito grande ou muito pequeno para caber em um inteiro de 64 bits assinado ou se tiver um componente fracionário.
Extensão de sinal
Os números são estendidos por sinais. Por exemplo, $bitsAnyClear
considera a posição de bit 200
definida para o número negativo -5
, mas a posição de bit 200
definida como o número positivo +5
.
Por outro lado, instâncias BinData
são estendidas a zero. Por exemplo, dado o seguinte documento:
db.collection.insertOne({ x: BinData(0, "ww=="), binaryValueofA: "11000011" })
$bitsAnyClear
vai considerar todos os bits fora de x
como limpos.
Exemplos
Os exemplos a seguir utilizarão uma coleção com os seguintes documentos:
db.collection.insertMany([ { _id: 1, a: 54, binaryValueofA: "00110110" }, { _id: 2, a: 20, binaryValueofA: "00010100" }, { _id: 3, a: 20.0, binaryValueofA: "00010100" }, { _id: 4, a: BinData(0, "Zg=="), binaryValueofA: "01100110" } ])
Array de posição de bits
A query a seguir usa o operador $bitsAnyClear
para testar se o campo a
está limpo na posição 1
ou na posição 5
, onde o bit menos significativo está na posição 0
.
db.collection.find( { a: { $bitsAnyClear: [ 1, 5 ] } } )
A consulta corresponde aos seguintes documentos:
{ "_id" : 2, "a" : 20, "binaryValueofA" : "00010100" } { "_id" : 3, "a" : 20.0, "binaryValueofA" : "00010100" }
Máscara de bits inteiros
A query a seguir usa o operador $bitsAnyClear
para testar se o campo a
tem algum bit limpo nas posições 0
, 1
e 5
(a representação binária da máscara de bits 35
é 00100011
).
db.collection.find( { a: { $bitsAnyClear: 35 } } )
A consulta corresponde aos seguintes documentos:
{ "_id" : 1, "a" : 54, "binaryValueofA" : "00110110" } { "_id" : 2, "a" : 20, "binaryValueofA" : "00010100" } { "_id" : 3, "a" : 20.0, "binaryValueofA" : "00010100" } { "_id" : 4, "a" : BinData(0,"Zg=="), "binaryValueofA" : "01100110" }
Máscara de bits BinData
A query a seguir usa o operador $bitsAnyClear
para testar se o campo a
tem algum bit limpo nas posições 4
e 5
(a representação binária de BinData(0, "MA==")
é 00110000
).
db.collection.find( { a: { $bitsAnyClear: BinData(0, "MA==") } } )
A consulta corresponde aos seguintes documentos:
{ "_id" : 2, "a" : 20, "binaryValueofA" : "00010100" } { "_id" : 3, "a" : 20.0, "binaryValueofA" : "00010100" } { "_id" : 4, "a" : BinData(0,"Zg=="), "binaryValueofA" : "01100110" }