Menu Docs
Página inicial do Docs
/
Manual do MongoDB
/ / /

$bitOr (agregação)

Nesta página

  • Definição
  • Sintaxe
  • Comportamento
  • Exemplos
  • Saiba mais

Novidades na versão 6.3.

$bitOr

Retorna o resultado de uma operação bitwise or em uma array de int e long valores.

O operador $bitOr tem a seguinte sintaxe:

{ $bitOr: { [ <expression1>, <expression2>, ... ] }

Se os operandos incluírem inteiros e valores longos, o sinal-estágios MongoDB o resultado inteiro calculado e retornará um valor longo. Caso contrário, se os operandos incluírem apenas inteiros ou apenas longos, o MongoDB retornará os resultados com o tipo de valor correspondente.

Observação

Todos os números em mongosh são duplos, não inteiros. Para especificar inteiros em mongosh, use o NumberInt() ou o construtor NumberLong() . Para saber mais, consulte Int32 ou Long.

Para saber como seu driver MongoDB lida com valores numéricos, consulte a documentação do driver.

Se algum argumento na array for de um tipo de dados diferente, como uma string, duplo ou decimal, o MongoDB retornará um erro.

Se o argumento for um array vazio, a operação retornará NumberInt(0).

Se qualquer um dos argumentos na array for igual a null, a operação retornará null.

Os exemplos nesta página utilizam a collection switches , que contém os seguintes documentos:

db.switches.insertMany( [
{ _id: 0, a: NumberInt(0), b: NumberInt(127) },
{ _id: 1, a: NumberInt(2), b: NumberInt(3) },
{ _id: 2, a: NumberInt(3), b: NumberInt(5) }
] )

A seguinte agregação utiliza o operador $bitOr no estágio $project :

db.switches.aggregate( [
{
$project: {
result: {
$bitOr: [ "$a", "$b" ]
}
}
}
])

A operação retorna os seguintes resultados:

[
{ _id: 0, result: 127 },
{ _id: 1, result: 3 },
{ _id: 2, result: 7 }
]

A seguinte agregação utiliza o operador $bitOr na etapa $project :

db.switches.aggregate( [
{
$project: {
result: {
$bitOr: [ "$a", NumberLong("63") ]
}
}
}
])

A operação retorna os seguintes resultados:

[
{ _id: 0, result: Long("0") },
{ _id: 1, result: Long("2") },
{ _id: 2, result: Long("3") }
]

Voltar

$bitNot