Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> MongoDB

เราสามารถใช้ NOT และ AND ร่วมกันใน MongoDB ได้หรือไม่?


ใช่ เราสามารถใช้ NOT และ AND ร่วมกันใน MongoDB ไวยากรณ์มีดังนี้

NOT X AND NOT Y = NOT (X AND Y)
Let us see the working of above syntax.
If both X and Y will be true then last result will be false.
If one of the operands gives result false then last result will be true.

ต่อไปนี้เป็นแบบสอบถามเพื่อสร้างคอลเลกชันที่มีเอกสาร

> db.NotAndDemo.insertOne({"StudentName":"John","StudentCountryName":"US"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c98746a330fd0aa0d2fe4a8")
}
> db.NotAndDemo.insertOne({"StudentName":"John","StudentCountryName":"UK"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c987478330fd0aa0d2fe4a9")
}
> db.NotAndDemo.insertOne({"StudentName":"David","StudentCountryName":"AUS"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c987487330fd0aa0d2fe4aa")
}
> db.NotAndDemo.insertOne({"StudentName":"Chris","StudentCountryName":"UK"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c9874ac330fd0aa0d2fe4ab")
}
> db.NotAndDemo.insertOne({"StudentName":"Chris","StudentCountryName":"US"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c9874b7330fd0aa0d2fe4ac")
}

ต่อไปนี้เป็นแบบสอบถามเพื่อแสดงเอกสารทั้งหมดจากคอลเลกชันโดยใช้วิธี find()

> db.NotAndDemo.find().pretty();
This will produce the following output:
{
   "_id" : ObjectId("5c98746a330fd0aa0d2fe4a8"),
   "StudentName" : "John",
   "StudentCountryName" : "US"
}
{
   "_id" : ObjectId("5c987478330fd0aa0d2fe4a9"),
   "StudentName" : "John",
   "StudentCountryName" : "UK"
}
{
   "_id" : ObjectId("5c987487330fd0aa0d2fe4aa"),
   "StudentName" : "David",
   "StudentCountryName" : "AUS"
}
{
   "_id" : ObjectId("5c9874ac330fd0aa0d2fe4ab"),
   "StudentName" : "Chris",
   "StudentCountryName" : "UK"
}
{
   "_id" : ObjectId("5c9874b7330fd0aa0d2fe4ac"),
   "StudentName" : "Chris",
   "StudentCountryName" : "US"
}

ต่อไปนี้เป็นแบบสอบถามที่จะใช้ NOT และ AND ร่วมกัน ซึ่งเหมือนกับ NOT X OR NOT Y for NOT (X AND Y)

> db.NotAndDemo.find({
...    "$or": [
...       {"StudentName": {"$ne": "Chris"}},
...       {"StudentCountryName": {"$ne": "US"}}
...    ]
... }).pretty();

สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้

{
   "_id" : ObjectId("5c98746a330fd0aa0d2fe4a8"),
   "StudentName" : "John",
   "StudentCountryName" : "US"
}
{
   "_id" : ObjectId("5c987478330fd0aa0d2fe4a9"),
   "StudentName" : "John",
   "StudentCountryName" : "UK"
}
{
   "_id" : ObjectId("5c987487330fd0aa0d2fe4aa"),
   "StudentName" : "David",
   "StudentCountryName" : "AUS"
}
{
   "_id" : ObjectId("5c9874ac330fd0aa0d2fe4ab"),
   "StudentName" : "Chris",
   "StudentCountryName" : "UK"
}