MongoDB: $nin 和 $in 在 $elemMatch 中無法配合使用以獲取包含主題“MongoDB”但又不包含“Java”的文件
對於這種獲取,僅使用 $nin 和 $in。讓我們建立一個包含文件的集合 −
> db.demo140.insertOne({"Id":101,"Subjects":["MongoDB","MySQL"]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e31c149fdf09dd6d08539a9")
}
> db.demo140.insertOne({"Id":102,"Subjects":["MongoDB","Java"]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e31c14cfdf09dd6d08539aa")
}
> db.demo140.insertOne({"Id":103,"Subjects":["MongoDB","PL/SQL"]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e31c157fdf09dd6d08539ab")
}
> db.demo140.insertOne({"Id":104,"Subjects":["MongoDB","SQL Server"]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e31c163fdf09dd6d08539ac")
}
> db.demo140.insertOne({"Id":105,"Subjects":["C","C++"]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e31c16ffdf09dd6d08539ad")
}使用 find() 方法顯示集合中的所有文件 −
> db.demo140.find();
這將產生以下輸出 −
{ "_id" : ObjectId("5e31c149fdf09dd6d08539a9"), "Id" : 101, "Subjects" : [ "MongoDB", "MySQL" ] }
{ "_id" : ObjectId("5e31c14cfdf09dd6d08539aa"), "Id" : 102, "Subjects" : [ "MongoDB", "Java" ] }
{ "_id" : ObjectId("5e31c157fdf09dd6d08539ab"), "Id" : 103, "Subjects" : [ "MongoDB", "PL/SQL" ] }
{ "_id" : ObjectId("5e31c163fdf09dd6d08539ac"), "Id" : 104, "Subjects" : [ "MongoDB", "SQL Server" ] }
{ "_id" : ObjectId("5e31c16ffdf09dd6d08539ad"), "Id" : 105, "Subjects" : [ "C", "C++" ] }以下是對包含主題“MongoDB”但又不包含“Java”的文件的查詢 −
> db.demo140.find({$and:[{Subjects:{$in:['MongoDB']}}, {Subjects:{$nin:['Java']}}]}).toArray();這將產生以下輸出 −
[
{
"_id" : ObjectId("5e31c149fdf09dd6d08539a9"),
"Id" : 101,
"Subjects" : [
"MongoDB",
"MySQL"
]
},
{
"_id" : ObjectId("5e31c157fdf09dd6d08539ab"),
"Id" : 103,
"Subjects" : [
"MongoDB",
"PL/SQL"
]
},
{
"_id" : ObjectId("5e31c163fdf09dd6d08539ac"),
"Id" : 104,
"Subjects" : [
"MongoDB",
"SQL Server"
]
}
]
廣告
資料結構
網路
RDBMS
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP