Mongo笔记7-bulkWrite

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> } }

] )

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值