Definición
$bitEl operador
$bitrealiza una actualización a nivel de bit de un campo. El operador soporta operaciones a nivel de bitand,oryxor, es decir, o exclusivo). Para especificar una expresión de operador$bit, utiliza el siguiente prototipo:{ $bit: { <field>: { <and|or|xor>: <int> } } } Utilice este operador únicamente con campos enteros (ya sean enteros de 32bits o enteros de 64bits).
Para especificar un
<field>en un documento incrustado o en una matriz, utilice notación de puntos.Nota
Todos los números en son dobles, no enteros.
mongoshUtiliceNumberInt()elNumberLong()constructor o para especificar enteros.Consulte Int32 o Long para más información.
Comportamiento
A partir de MongoDB 5.0, mongod ya no genera un error cuando utiliza un operador de actualización como $bit con una expresión de operando vacía ( { } ). Una actualización vacía no produce cambios y no genera ninguna entrada en el oplog (lo que significa que la operación es una “no-op").
A partir de MongoDB 5.0, los operadores de actualización procesan los campos de documentos con nombres basados en cadenas en orden lexicográfico. Los campos con nombres numéricos se procesan en orden numérico. Consulta Comportamiento del operador de actualización para obtener más información.
Ejemplos
Los siguientes ejemplos utilizan la colección switches:
db.switches.insertMany( [ { _id: 1, expdata: Int32(13) }, { _id: 2, expdata: Int32(3) }, { _id: 3, expdata: Int32(1) } ] )
AND bit a bit
Utilice un bit a bit and en la operación updateOne() para expdata actualizar.
db.switches.updateOne( { _id: 1 }, { $bit: { expdata: { and: Int32( 10 ) } } } )
La operación bit a bit and:
obtiene el valor bit a bit de
expdatautiliza
andpara aplicar el valor bit a bit de Int32(10)actualiza
expdatacon el resultado, 1000
1101 // expdata 1010 // Int32(10) ---- 1000
El valor binario 1000 equivale a Int32(8). El comando db.switches.find( { _id: 1 } ) devuelve el siguiente documento:
{ "_id" : 1, "expdata" : 8 }
OR bit a bit
Utilice un bit a bit or en la operación updateOne() para expdata actualizar.
db.switches.updateOne( { _id: 2 }, { $bit: { expdata: { or: Int32( 5 ) } } } )
La operación bit a bit or:
obtiene el valor bit a bit de
expdatautiliza
orpara aplicar el valor bit a bit de Int32(5)actualiza
expdatacon el resultado, 0111
0111 // expdata 0101 // Int32(5) ---- 0111
El valor binario 0111 equivale a Int32(7). El comando db.switches.find( { _id: 2 } ) devuelve el siguiente documento:
{ "_id" : 2, "expdata" : 7 }
Bitwise XOR
Utilice un bit a bit xor en la operación updateOne() para expdata actualizar.
db.switches.updateOne( { _id: 3 }, { $bit: { expdata: { xor: Int32( 5 ) } } } )
La operación bit a bit and:
obtiene el valor bit a bit de
expdatautiliza
andpara aplicar el valor bit a bit de Int32(5)actualiza
expdatacon el resultado, 0100
0001 // expdata 0101 // Int32(5) ---- 0100
El binario 0100 equivale a Int32(4). El comando db.switches.find( { _id: 3 } ) devuelve el siguiente documento:
{ "_id" : 1, "expdata" : 4 }