Docs 菜单

Docs 主页开发应用程序MongoDB Manual

Bulk.getOperations()

在此页面上

  • 例子
  • 返回的字段
Bulk.getOperations()

返回通过Bulk.execute()执行的写入操作的数组。 返回的写入操作按 MongoDB 确定的分组执行。 有关 MongoDB 如何对批量写入操作列表进行分组的信息,请参阅Bulk.execute() 行为。

仅在 之后使用Bulk.getOperations() }。在调用Bulk.execute()Bulk.getOperations() Bulk.execute()} 将导致列表 不完整

以下示例在items集合上初始化Bulk()操作构建器,添加一系列写入操作,执行这些操作,然后在bulk构建器对象上调用getOperations()

var bulk = db.items.initializeUnorderedBulkOp();
for (var i = 1; i <= 1500; i++) {
bulk.insert( { x: i } );
}
bulk.execute();
bulk.getOperations();

getOperations()方法返回一个包含已执行操作的数组。输出显示 MongoDB 将操作分为2组,一组包含1000操作,另一组包含500操作。有关 MongoDB 如何对批量写入操作列表进行分组的信息,请参阅Bulk.execute() 行为

虽然该方法会返回返回数组中的所有 1500 个操作,但为了简洁起见,本页省略了一些结果。

[
{
"originalZeroIndex" : 0,
"batchType" : 1,
"operations" : [
{ "_id" : ObjectId("53a8959f1990ca24d01c6165"), "x" : 1 },
... // Content omitted for brevity
{ "_id" : ObjectId("53a8959f1990ca24d01c654c"), "x" : 1000 }
]
},
{
"originalZeroIndex" : 1000,
"batchType" : 1,
"operations" : [
{ "_id" : ObjectId("53a8959f1990ca24d01c654d"), "x" : 1001 },
... // Content omitted for brevity
{ "_id" : ObjectId("53a8959f1990ca24d01c6740"), "x" : 1500 }
]
}
]

该数组包含具有以下字段的文档:

originalZeroIndex

指定基于零索引将操作添加到批量操作构建器的顺序;例如,添加到批量操作构建器中的第一个操作的originalZeroIndex值为0

batchType

指定写入操作类型。

batchType
操作
1
插入
2
更新(Update)
3
删除
operations

包含操作详细信息的文档数组。

提示

另请参阅:

← Bulk.find.upsert()

在此页面上