MongoDB
 Computer >> コンピューター >  >> プログラミング >> MongoDB

配列内の複数の基準をMongoDBと一致させる方法は?


配列内の複数の基準に一致させるには、aggregate()を使用します。ドキュメントを使用してコレクションを作成しましょう-

> db.demo84.insertOne({
...    "EmployeeDetails": [
...       {Name: 'John', Salary:45000, isMarried: true},
...       {Name: 'Chris', Salary:50000, isMarried: false}
...       ]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e2c0a3471bf0181ecc422a5")
}
> db.demo84.insertOne({
...    "EmployeeDetails": [
...       {Name: 'Sam', Salary:56000, isMarried: false},
...       {Name: 'Bob', Salary:50000, isMarried: false}
...       ]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e2c0a4071bf0181ecc422a6")
}

find()メソッドを使用してコレクションからすべてのドキュメントを表示する-

> db.demo84.find();

これにより、次の出力が生成されます-

{
   "_id" : ObjectId("5e2c0a3471bf0181ecc422a5"), "EmployeeDetails" : [
      { "Name" : "John", "Salary" : 45000, "isMarried" : true },
      { "Name" : "Chris", "Salary" : 50000, "isMarried" : false }
   ]
}
{
   "_id" : ObjectId("5e2c0a4071bf0181ecc422a6"), "EmployeeDetails" : [
      { "Name" : "Sam", "Salary" : 56000, "isMarried" : false },
      { "Name" : "Bob", "Salary" : 50000, "isMarried" : false }
   ]
}

以下は、配列内の複数の基準に一致するクエリです-

> db.demo84.aggregate(
...    { "$match": {
...       "EmployeeDetails": {
...          "$elemMatch": {
...             "Name": "Chris",
...          "isMarried": false
...          }
...       }
...    }}
... );

これにより、次の出力が生成されます-

{
   "_id" : ObjectId("5e2c0a3471bf0181ecc422a5"), "EmployeeDetails" : [
      { "Name" : "John", "Salary" : 45000, "isMarried" : true },
      { "Name" : "Chris", "Salary" : 50000, "isMarried" : false }
   ] 
}

  1. オブジェクトの配列内で複数の一致を見つけるためのMongoDBクエリ?

    これには、$andを$regexと一緒に使用します。 $ andは、1つ以上の式の配列に対して論理積演算を実行し、配列内のすべての式を満たすドキュメントを選択します。 ドキュメントを使用してコレクションを作成しましょう- > db.demo525.insertOne({"details":[{Name:"Chris","CountryName":"US"}]});{    "acknowledged" : true,    "insert

  2. MongoDBの配列フィールドを操作してすべてに一致させるにはどうすればよいですか?

    MongoDBのすべてに一致させるには、$allを使用します。 $ all演算子は、フィールドの値が指定されたすべての要素を含む配列であるドキュメントを選択します。ドキュメントを使用してコレクションを作成しましょう- > db.demo695.insertOne({"ListOfValues":[100,200,500,800]}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea6d4c4551299a9f