批量写入操作
db.collection.bulkWrite()方法提供了执行批量插入,更新和删除操作的能力。
批量写操作可以是有序的,如果在某个单独的写操作的处理过程中发生错误,MongoDB将直接返回而不再继续处理列表中任何剩余的写操作。默认有序。
db.characters.bulkWrite([...], {ordered: true});
也可以无序的,如果某个单独的写操作的处理过程中发生错误,MongoDB将继续处理列表中剩余的写操作。
db.characters.bulkWrite([...], {ordered: false});
bulkWrite() 支持如下操作:
- insertOne
- updateOne
- updateMany
- replaceOne
- deleteOne
- deleteMany
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 }
}
}
]
);