MongoDB为客户端提供了批量执行写操作的能力。批量写操作影响单个集合。MongoDB允许应用程序确定批量写入操作所需的可接受的确认级别。
bulkwrite()方法提供了执行批量插入、更新和删除操作的能力。MongoDB还支持通过db.collection.insertMany()进行批量插入。
批量写操作可以是有序的,也可以是非有序的。
对于一个有序的操作列表,MongoDB串行执行操作。如果在一个写操作的处理过程中发生错误,MongoDB将返回,而不处理列表中任何剩余的写操作。参见有序批量写入
使用无序的操作列表,MongoDB可以并行执行操作,但是这种行为不能保证。如果在处理一个写操作时发生错误,MongoDB将继续处理列表中剩余的写操作。参见无序批量写入。
在切分集合上执行有序操作列表通常比执行无序列表慢,因为对于有序列表,每个操作都必须等待上一个操作完成。
默认情况下,bulkWrite()执行有序操作。若要指定无序写入操作,请在选项文档中设置ordered: false。
格式:
db.collection.bulkWrite( [ <operation 1>, <operation 2>, ... ], { writeConcern : <document>, ordered : <boolean> } )
- A boolean acknowledged as true if the operation ran with write concern or false if write concern was disabled.
- A count for each write operation.
- An array containing an _id for each successfully inserted or upserted documents.
try {
db.characters.bulkWrite(
[
{ insertOne :
{
"document" :
{
"_id" : 4, "char" : "Dithras", "class" : "barbarian", "lvl" : 4
}
}
},
{ insertOne :
{
"document" :
{
"_id" : 5, "char" : "Taeln", "class" : "fighter", "lvl" : 3
}
}
},
{ updateOne :
{
"filter" : { "char" : "Eldon" },
"update" : { $set : { "status" : "Critical Injury" } }
}
},
{ deleteOne :
{ "filter" : { "char" : "Brisbane"} }
},
{ replaceOne :
{
"filter" : { "char" : "Meldane" },
"replacement" : { "char" : "Tanys", "class" : "oracle", "lvl" : 4 }
}
}
]
);
}
catch (e) {
print(e);
}
try {
db.characters.bulkWrite([
{ insertOne: { "document": { "_id": 4, "char": "Dithras", "class": "barbarian", "lvl": 4 } } },
{ insertOne: { "document": { "_id": 4, "char": "Taeln", "class": "fighter", "lvl": 3 } } },
{ updateOne : {
"filter" : { "char" : "Eldon" },
"update" : { $set : { "status" : "Critical Injury" } }
} },
{ deleteOne : { "filter" : { "char" : "Brisbane"} } },
{ replaceOne : {
"filter" : { "char" : "Meldane" },
"replacement" : { "char" : "Tanys", "class" : "oracle", "lvl": 4 }
} }
], { ordered : false } );
} catch (e) {
print(e);
}
db.collection.bulkWrite( [
{ insertOne : { "document" : <document> } }
] )
db.collection.bulkWrite( [
{ updateOne :
{
"filter" : <document>,
"update" : <document>,
"upsert" : <boolean>,
"collation": <document>,
"arrayFilters": [ <filterdocument1>, ... ]
}
}
] )
db.collection.bulkWrite( [
{ updateMany :
{
"filter" : <document>,
"update" : <document>,
"upsert" : <boolean>,
"collation": <document>,
"arrayFilters": [ <filterdocument1>, ... ]
}
}
] )
db.collection.bulkWrite([
{ replaceOne :
{
"filter" : <document>,
"replacement" : <document>,
"upsert" : <boolean>
}
}
] )
db.collection.bulkWrite([
{ deleteOne : { "filter" : <document> } }
] )
db.collection.bulkWrite([
{ deleteMany : { "filter" : <document> } }
] )