Definición
Nuevo en la versión 6.3.
Sintaxis
El operador $bitOr tiene la siguiente sintaxis:
{ $bitOr: [ <expression1>, <expression2>, ... ] }
Comportamiento
Si los operandos incluyen enteros y valores long, MongoDB extiende el resultado entero calculado y devuelve un valor long. De lo contrario, si los operandos incluyen solo enteros o long, MongoDB devuelve resultados con el tipo de valor correspondiente.
Nota
Todos los números en mongosh son dobles, no enteros. Para especificar enteros en,mongosh utilice Int32() el Long() constructor o. Para obtener más información, consulte Int32 o Long.
Para saber cómo su controlador MongoDB maneja los valores numéricos, consulte la documentación de su controlador.
Si alguno de los argumentos de la matriz es de un tipo de datos diferente, como una cadena, un doble o un decimal, MongoDB devuelve un error.
Si el argumento es una matriz vacía, la operación devuelve Int32(0).
Si alguno de los argumentos de la matriz equivale a null, la operación devuelve null.
Ejemplos
Los ejemplos de esta página utilizan la colección switches, que contiene los siguientes documentos:
db.switches.insertMany( [ { _id: 0, a: Int32(0), b: Int32(127) }, { _id: 1, a: Int32(2), b: Int32(3) }, { _id: 2, a: Int32(3), b: Int32(5) } ] )
Bit a bit OR con dos enteros
La siguiente agregación utiliza el operador $bitOr en el
$project escenario:
db.switches.aggregate( [ { $project: { result: { $bitOr: [ "$a", "$b" ] } } } ])
La operación devuelve los siguientes resultados:
[ { _id: 0, result: 127 }, { _id: 1, result: 3 }, { _id: 2, result: 7 } ]
Bitwise OR con un valor largo y entero
La siguiente agregación utiliza el $bitOr operador en la $project etapa:
db.switches.aggregate( [ { $project: { result: { $bitOr: [ "$a", Long("63") ] } } } ])
La operación devuelve los siguientes resultados:
[ { _id: 0, result: Long("0") }, { _id: 1, result: Long("2") }, { _id: 2, result: Long("3") } ]