ใช่ เราสามารถใช้ 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" }