如何解決 MongoDb 中的“多更新僅適用於 $ 運算子”的問題?
你可以為此使用 $set 運算子。語法如下所示 −
db.yourCollectionName.update({ }, {'$set': "yourFieldName": "yourValue" }, false, true);為了理解上述語法,我們建立一個具有文件的集合。用於建立帶有文件的集合的查詢如下 −
> db.unconditionalUpdatesDemo.insertOne({"ClientName":"Larry","ClientAge":24});
{
"acknowledged" : true,
"insertedId" : ObjectId("5c8eb7372f684a30fbdfd557")
}
> db.unconditionalUpdatesDemo.insertOne({"ClientName":"Mike","ClientAge":26});
{
"acknowledged" : true,
"insertedId" : ObjectId("5c8eb73f2f684a30fbdfd558")
}
> db.unconditionalUpdatesDemo.insertOne({"ClientName":"Sam","ClientAge":27});
{
"acknowledged" : true,
"insertedId" : ObjectId("5c8eb7462f684a30fbdfd559")
}
> db.unconditionalUpdatesDemo.insertOne({"ClientName":"Carol","ClientAge":29});
{
"acknowledged" : true,
"insertedId" : ObjectId("5c8eb7502f684a30fbdfd55a")
}使用 find() 方法從某個集合顯示所有文件。查詢如下 −
> db.unconditionalUpdatesDemo.find().pretty();
以下是輸出 −
{
"_id" : ObjectId("5c8eb7372f684a30fbdfd557"),
"ClientName" : "Larry",
"ClientAge" : 24
}
{
"_id" : ObjectId("5c8eb73f2f684a30fbdfd558"),
"ClientName" : "Mike",
"ClientAge" : 26
}
{
"_id" : ObjectId("5c8eb7462f684a30fbdfd559"),
"ClientName" : "Sam",
"ClientAge" : 27
}
{
"_id" : ObjectId("5c8eb7502f684a30fbdfd55a"),
"ClientName" : "Carol",
"ClientAge" : 29
}以下是無條件更新的查詢 −
> db.unconditionalUpdatesDemo.update({ }, {'$set': {"ClientName": "Robert" }}, false, true);
WriteResult({ "nMatched" : 4, "nUpserted" : 0, "nModified" : 4 })讓我們使用 find() 從某個集合檢視文件。查詢如下 −
> db.unconditionalUpdatesDemo.find().pretty();
以下是輸出 −
{
"_id" : ObjectId("5c8eb7372f684a30fbdfd557"),
"ClientName" : "Robert",
"ClientAge" : 24
}
{
"_id" : ObjectId("5c8eb73f2f684a30fbdfd558"),
"ClientName" : "Robert",
"ClientAge" : 26
}
{
"_id" : ObjectId("5c8eb7462f684a30fbdfd559"),
"ClientName" : "Robert",
"ClientAge" : 27
}
{
"_id" : ObjectId("5c8eb7502f684a30fbdfd55a"),
"ClientName" : "Robert",
"ClientAge" : 29
}
Advertisement 廣告
資料結構
網路
關係型資料庫管理系統
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP