MongoDB のフィールドを比較する

MD Aminul Islam 2023年6月20日
  1. MongoDB のフィールドを比較する
  2. MongoDB で 2つのフィールドを比較する例
MongoDB のフィールドを比較する

場合によっては、2つのフィールドを比較してドキュメントを見つける必要があります。 たとえば、MongoDB コレクション内のドキュメントを選択するときに、シリアル番号と ID 番号を考慮する必要がある場合があります。 これについては、このチュートリアルの後半で説明します。

この記事では、MongoDB で 2つのフィールドを比較する方法について説明します。 また、トピックを簡単にするための説明とともに、関連する例を示します。

MongoDB のフィールドを比較する

この目的で使用できる手法は 2つあります。 MongoDB コレクションからドキュメントを検索または抽出するために使用される組み込みメソッド find() を両方の手法に使用します。

最初の手法では、主に特定の条件に一致するキーワード $where を使用します。 2 番目の手法では、キーワード $expr を使用して単純な集計を使用します。これにより、集計式を引数として実装できます。

わかりやすくするために例を見てみましょう。

MongoDB で 2つのフィールドを比較する例

以下の例では、MongoDB の 2つのフィールドを比較する方法を示します。 sl フィールドと id フィールドを比較します。

さて、この目的のためのコマンドは次のとおりです。

$where キーワードの使用:

db.mycolletion.find( { $where : "this.sl < this.id" } );

$expr キーワードの使用:

db.mycolletion.find({$expr:{$lt:["$sl", "$id"]}})

上記のコマンドで、$lt は比較演算子です。 必要に応じて使用できる他の比較演算子があります。

MongoDB で利用可能な比較演算子

以下では、MongoDB の集計で使用される使用可能な比較演算子を共有しました。

  • $eq - これは等号演算子を表します。
  • $ne - これは Not Equal 演算子を表します。
  • $gt - これは大なり演算子を表します。
  • $gte - これは、より大きいか等しい演算子を表します。
  • $lt - これは、Less Than 演算子を表します。
  • $lte - これは、Less Than or Equal 演算子を表します。
  • $in - これは、配列内の任意の値に一致します。
  • $nin - これは、配列内のどの値とも一致しません。

ここで、上記で共有された両方のコマンドで、以下と同じ結果が得られます。

{ _id: ObjectId("6371fd850f19826ee6ca5138"),
  sl: 0,
  Name: 'Alen',
  id: '3'
}

注: 適切なコレクションに含まれているかどうかを確認してください。 特定のコレクションをオンにするには、コマンド use YourDB を使用します。 そうしないと、エラーが発生します。

この記事に示されているコマンドは MongoDB データベース用であり、コマンドは MongoDB コンソールで実行する必要があることに注意してください。

著者: MD Aminul Islam
MD Aminul Islam avatar MD Aminul Islam avatar

Aminul Is an Expert Technical Writer and Full-Stack Developer. He has hands-on working experience on numerous Developer Platforms and SAAS startups. He is highly skilled in numerous Programming languages and Frameworks. He can write professional technical articles like Reviews, Programming, Documentation, SOP, User manual, Whitepaper, etc.

LinkedIn