Docs Menu

$bitXor (aggregation)

バージョン 6.3 で追加

$bitXor

intlong の値の配列に対するビット単位の xor (排他的論理和) 演算の結果を返します。

$bitXor演算子の構文は次のとおりです。

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

オペランドに整数と long 値の両方が含まれている場合、MongoDB は計算された整数結果を符号拡張し、long 値を返します。 そうではなく、オペランドに整数のみまたは long のみが含まれている場合、MongoDB は対応する値の型を持つ結果を返します。

注意

mongosh内のすべての数値は、整数ではなく double です。 mongoshで整数を指定するには、 NumberInt()またはNumberLong()コンストラクターを使用します。 詳しくは、「 Int 32またはLong 」を参照してください。

MongoDB ドライバーが数値を処理する方法については、ドライバーのドキュメント を参照してください。

配列内のいずれかの引数がstring、double、decimal など、異なるデータ型である場合、MongoDB はエラーを返します。

引数が空の配列の場合、操作はNumberInt(0)を返します。

If any of the arguments in the array equate to null, the operation returns null.

このページの例では、 switchesコレクションを使用しています。

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) }
] )

次の集計では、 $projectステージで$bitXor演算子が使用されています。

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

この操作は次の結果を返します。

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