使用位置運算子在 MongoDB 中查詢資料?
使用 $pull 運算子和位置運算子 ($) 在 MongoDB 中進行查詢。我們首先建立一個包含文件的集合 -
> db.pullWithPositionalOperatorDemo.insertOne(
... {
... _id: 100,
... "StudentDetails": [
... {
... "StudentId": "STU-1",
... "StudentFavouriteSubject": ["MongoDB", "Java"]
... },
... {
... "StudentId": "STU-2",
... "StudentFavouriteSubject": ["PHP", "MySQL"]
... }
... ]
... }
... );
{ "acknowledged" : true, "insertedId" : 100 }以下查詢使用 find() 方法顯示集合中的所有文件 -
> db.pullWithPositionalOperatorDemo.find().pretty();
此查詢將生成以下輸出 -
{
"_id" : 100,
"StudentDetails" : [
{
"StudentId" : "STU-1",
"StudentFavouriteSubject" : [
"MongoDB",
"Java"
]
},
{
"StudentId" : "STU-2",
"StudentFavouriteSubject" : [
"PHP",
"MySQL"
]
}
]
}以下查詢使用位置運算子執行查詢 -
> db.pullWithPositionalOperatorDemo.update({
... "StudentDetails" : {
... "$elemMatch" : {
... "StudentId" : "STU-2",
... "StudentFavouriteSubject" : "MySQL"
... }
... }
... }, {
... $pull : {
... "StudentDetails.$.StudentFavouriteSubject" : "MySQL"
... }
... }, {
... multi : true
... });
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })讓我們再次檢查上述集合中的所有文件 -
> db.pullWithPositionalOperatorDemo.find().pretty();
此查詢將生成以下輸出 -
{
"_id" : 100,
"StudentDetails" : [
{
"StudentId" : "STU-1",
"StudentFavouriteSubject" : [
"MongoDB",
"Java"
]
},
{
"StudentId" : "STU-2",
"StudentFavouriteSubject" : [
"PHP"
]
}
]
}
廣告
資料結構
網路
RDBMS
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式語言
C++
C#
MongoDB
MySQL
Javascript
PHP