MongoDB查詢檢查陣列屬性中的值?
你可以使用 $in 運算子來檢視一個值是否在陣列中。我們首先使用文件建立一個集合 -
> db.valueInArrayDemo.insertOne({"UserName":"John","UserMessage":["Hi","Hello","Bye"]}); { "acknowledged" : true, "insertedId" : ObjectId("5cd684cf7924bb85b3f48959") } > db.valueInArrayDemo.insertOne({"UserName":"Larry","UserMessage":["Thank You","Amazing","Nice"]}); { "acknowledged" : true, "insertedId" : ObjectId("5cd684d27924bb85b3f4895a") } >db.valueInArrayDemo.insertOne({"UserName":"Carol","UserMessage":["Awesome","Bye","Cool"]}); { "acknowledged" : true, "insertedId" : ObjectId("5cd684d87924bb85b3f4895b") }
以下使用 find() 方法顯示集合中所有文件的查詢 -
> db.valueInArrayDemo.find().pretty();
這將生成以下輸出 -
{
"_id" : ObjectId("5cd684cf7924bb85b3f48959"),
"UserName" : "John",
"UserMessage" : [
"Hi",
"Hello",
"Bye"
]
}
{
"_id" : ObjectId("5cd684d27924bb85b3f4895a"),
"UserName" : "Larry",
"UserMessage" : [
"Thank You",
"Amazing",
"Nice"
]
}
{
"_id" : ObjectId("5cd684d87924bb85b3f4895b"),
"UserName" : "Carol",
"UserMessage" : [
"Awesome",
"Bye",
"Cool"
]
}以下使用 $in 檢查特定值是否在陣列中的查詢 -
> db.valueInArrayDemo.find({UserMessage:{$in:["Bye"]}});
這將生成以下輸出 -
{ "_id" : ObjectId("5cd684cf7924bb85b3f48959"), "UserName" : "John", "UserMessage" : [ "Hi", "Hello", "Bye" ] }
{ "_id" : ObjectId("5cd684d87924bb85b3f4895b"), "UserName" : "Carol", "UserMessage" : [ "Awesome", "Bye", "Cool" ] }
廣告
資料結構
網路
關係型資料庫管理系統
作業系統
Java
iOS
HTML
CSS
安卓
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP