Docs Menu
Docs Home
/ /

Bulk Operations

In this guide, you can learn how to use the Node.js driver to perform bulk operations. Bulk operations help reduce the number of calls to the server. Instead of sending a request for each operation, you can perform multiple operations within one action.

Tip

To learn more about bulk operations, see Bulk Write Operations in the MongoDB Server manual.

You can use bulk operations to perform multiple write operations on a collection. You can also run bulk operations from the client, which allows you to perform bulk writes across multiple namespaces. In MongoDB, a namespace consists of the database name and the collection name in the format <database>.<collection>.

This guide includes the following sections:

  • Bulk Insert Operations describes how to perform bulk insert operations on your collection or client.

  • Bulk Replace Operations describes how to perform bulk replace operations on your collection or client.

  • Bulk Update Operations describes how to perform bulk update operations on your collection or client.

  • Bulk Delete Operations describes how to perform bulk delete operations on your collection or client.

  • Return Type describes the return object that results from your bulk write operations.

  • Handling Exceptions describes the exceptions that occur if any of the operations in a bulk write operation fail.

  • Additional Information provides links to resources and API documentation for types and methods mentioned in this guide.

Important

Server and Driver Version Requirements

Collection-level bulk write operations require the following versions:

  • MongoDB Server version 3.2 or later

  • Node.js driver version 3.6 or later

Client-level bulk write operations require the following versions:

  • MongoDB Server version 8.0 or later

  • Node.js driver version 6.10 or later

The examples in this guide use the movies and users collections in the sample_mflix database, which is included in the Atlas sample datasets. To learn how to create a free MongoDB Atlas cluster and load the sample datasets, see the Get Started with Atlas guide.

To perform a bulk insert operation, create a bulk operation model for each document you want to insert. Then, pass a list of these models to the bulkWrite() method.

This section describes how to perform the following types of bulk operations:

To perform a bulk insert operation on your collection, create an InsertOneModel for each operation. Then, call the bulkWrite() method on your collection and pass an array of models as a parameter. To create an InsertOneModel, specify the model's document field and set it to the document you want to insert.

This example performs the following actions:

  1. Specifies two InsertOneModel instances in an array. Each InsertOneModel represents a document to insert into the movies collection in the sample_mflix database.

  2. Calls the bulkWrite() method on the movies collection and passes an array of models as a parameter.

  3. Prints the number of inserted documents.

const insertModels = [{
insertOne: {
document: {
title: "The Favourite",
year: 2018,
rated: "R",
released: "2018-12-21"
}
}
}, {
insertOne: {
document: {
title: "I, Tonya",
year: 2017,
rated: "R",
released: "2017-12-08"
}
}
}];
const insertResult = await movies.bulkWrite(insertModels);
console.log(`Inserted documents: ${insertResult.insertedCount}`);
Inserted documents: 2

To perform a bulk insert operation across multiple collections or databases, create a ClientBulkWriteModel for each operation. Then, call the bulkWrite() method on your client and pass an array of models as a parameter.

The following table describes the fields that you can set in a ClientBulkWriteModel to specify an insert operation:

Field
Description

namespace

The namespace in which to insert a document.
Type: String

name

The operation you want to perform. For insert operations, set this field to "insertOne".
Type: String

document

The document to insert.
Type: Document

This example performs the following actions:

  1. Specifies three ClientBulkWriteModel instances in an array. The first two models represent documents to insert into the movies collection, and the last model represents a document to insert into the users collection.

  2. Calls the bulkWrite() method on a client and passes an array of models as a parameter.

  3. Prints the number of inserted documents.

const clientInserts = [{
namespace: "sample_mflix.movies",
name: "insertOne",
document: {
title: "The Favourite",
year: 2018,
rated: "R",
released: "2018-12-21"
}
}, {
namespace: "sample_mflix.movies",
name: "insertOne",
document: {
title: "I, Tonya",
year: 2017,
rated: "R",
released: "2017-12-08"
}
}, {
namespace: "sample_mflix.users",
name: "insertOne",
document: {
name: "Brian Schwartz",
email: "bschwartz@example.com"
}
}];
const clientInsertRes = await client.bulkWrite(clientInserts);
console.log(`Inserted documents: ${clientInsertRes.insertedCount}`);
Inserted documents: 3

To perform a bulk replace operation, create a bulk operation model for each document you want to replace. Then, pass a list of these models to the bulkWrite() method.

This section describes how to perform the following types of bulk operations:

To perform a bulk replace operation on your collection, create a ReplaceOneModel for each operation. Then, call the bulkWrite() method on your collection and pass an array of models as a parameter.

The following table describes the fields that you can set in a ReplaceOneModel:

Field
Description

filter

The filter that matches the document you want to replace.
Type: Document

replacement

The replacement document.
Type: Document

collation

(Optional) The collation to use when sorting results. To learn more about collations, see the Collation section of the Configure CRUD Operations guide.
Type: String or Object

hint

(Optional) The index to use for the operation. To learn more about indexes, see the Indexes on Collections guide.
Type: Bson

upsert

(Optional) Whether a new document is created if no document matches the filter.
By default, this field is set to false.
Type: Boolean

This example performs the following actions:

  1. Specifies two ReplaceOneModel instances in an array. The ReplaceOneModel instances contain instructions to replace documents representing movies in the movies collection.

  2. Calls the bulkWrite() method on the movies collection and passes an array of models as a parameter.

  3. Prints the number of modified documents.

const replaceOperations = [{
replaceOne: {
filter: {
title: "The Dark Knight"
},
replacement: {
title: "The Dark Knight Rises",
year: 2012,
rating: "PG-13"
},
upsert: false
}
}, {
replaceOne: {
filter: {
title: "Inception"
},
replacement: {
title: "Inception Reloaded",
year: 2010,
rating: "PG-13"
},
upsert: false
}
}];
const replaceResult = await movies.bulkWrite(replaceOperations);
console.log(`Modified documents: ${replaceResult.modifiedCount}`);
Modified documents: 2

To perform a bulk replace operation across multiple collections or databases, create a ClientBulkWriteModel for each operation. Then, call the bulkWrite() method on your client and pass an array of models as a parameter.

The following table describes the fields that you can set in a ClientBulkWriteModel to specify a replace operation:

Field
Description

namespace

The namespace in which to replace a document.
Type: String

name

The operation you want to perform. For replace operations, set this field to "replaceOne".
Type: String

filter

The filter that matches the document you want to replace.
Type: Document

replacement

The replacement document.
Type: Document

collation

(Optional) The collation to use when sorting results. To learn more about collations, see the Collation section of the Configure CRUD Operations guide.
Type: String or Object

hint

(Optional) The index to use for the operation. To learn more about indexes, see the Indexes on Collections guide.
Type: Bson

This example performs the following actions:

  1. Specifies three ClientBulkWriteModel instances in an array. The first two models contain replacement instructions for documents in the movies collection, and the last model contains replacement instructions for a document in the users collection.

  2. Calls the bulkWrite() method on a client and passes an array of models as a parameter.

  3. Prints the number of modified documents.

const clientReplacements = [{
namespace: "sample_mflix.movies",
name: "replaceOne",
filter: {
title: "The Dark Knight"
},
replacement: {
title: "The Dark Knight Rises",
year: 2012,
rating: "PG-13"
}
}, {
namespace: "sample_mflix.movies",
name: "replaceOne",
filter: {
title: "Inception"
},
replacement: {
title: "Inception Reloaded",
year: 2010,
rating: "PG-13"
}
}, {
namespace: "sample_mflix.users",
name: "replaceOne",
filter: {
name: "April Cole"
},
replacement: {
name: "April Franklin",
email: "aprilfrank@example.com"
}
}];
const clientReplaceRes = await client.bulkWrite(clientReplacements);
console.log(`Modified documents: ${clientReplaceRes.modifiedCount}`);
Modified documents: 3

To perform a bulk update operation, create a bulk operation model for each update you want to make. Then, pass a list of these models to the bulkWrite() method.

This section describes how to perform the following types of bulk operations:

To perform a bulk update operation on your collection, create an UpdateOneModel or UpdateManyModel for each operation. Then, call the bulkWrite() method on your collection and pass an array of models as a parameter. An UpdateOneModel updates only one document that matches a filter, while an UpdateManyModel updates all documents that match a filter.

The following table describes the fields you can set in an UpdateOneModel or UpdateManyModel:

Field
Description

filter

The filter that matches one or more documents you want to update. When specified in an UpdateOneModel, only the first matching document will be updated. When specified in an UpdateManyModel, all matching documents will be updated.
Type: Document

update

The update to perform.
Type: Document

arrayFilters

(Optional) A set of filters specifying which array elements an update applies to if you are updating an array-valued field.
Type: Array

collation

(Optional) The collation to use when sorting results. To learn more about collations, see the Collation section of the Configure CRUD Operations guide.
Type: Object

hint

(Optional) The index to use for the operation. To learn more about indexes, see the Indexes on Collections guide.
Type: String or Object

upsert

(Optional) Whether a new document is created if no document matches the filter. By default, this field is set to false.
Type: Boolean

This example performs the following actions:

  1. Specifies an UpdateOneModel and an UpdateManyModel instance in an array. These models contain instructions to update documents representing movies in the movies collection.

  2. Calls the bulkWrite() method on the movies collection and passes an array of models as a parameter.

  3. Prints the number of modified documents.

const updateOperations = [{
updateOne: {
filter: {
title: "Interstellar"
},
update: {
$set: {
title: "Interstellar Updated",
genre: "Sci-Fi Adventure"
}
},
upsert: true
}
}, {
updateMany: {
filter: {
rated: "PG-13"
},
update: {
$set: {
rated: "PG-13 Updated",
genre: "Updated Genre"
}
}
}
}];
const updateResult = await movies.bulkWrite(updateOperations);
console.log(`Modified documents: ${updateResult.modifiedCount}`);
Modified documents: 2320

To perform a bulk update operation across multiple collections or databases, create a ClientBulkWriteModel for each operation. Then, call the bulkWrite() method on your client and pass an array of models as a parameter.

The following table describes the fields you can set in a ClientBulkWriteModel to specify an update operation:

Field
Description

namespace

The namespace in which to update a document.
Type: String

name

The operation you want to perform. For update operations, set this field to "updateOne" or "updateMany".
Type: String

filter

The filter that matches one or more documents you want to update. If you set the model name to "updateOne", only the first matching document is updated. If you set name to "updateMany", all matching documents are updated.
Type: Document

update

The updates to perform.
Type: Document or Document[]

arrayFilters

(Optional) A set of filters specifying which array elements an update applies to if you are updating an array-valued field.
Type: Document[]

collation

(Optional) The collation to use when sorting results. To learn more about collations, see the Collation section of the Configure CRUD Operations guide.
Type: Document

hint

(Optional) The index to use for the operation. To learn more about indexes, see the Indexes on Collections guide.
Type: Document or String

upsert

(Optional) Whether a new document is created if no document matches the filter. By default, this field is set to false.
Type: Boolean

This example performs the following actions:

  1. Specifies two ClientBulkWriteModel instances in an array. The first model specifies an update many operation on the movies collection, and the second model specifies an update one operation on the users collection.

  2. Calls the bulkWrite() method on a client and passes an array of models as a parameter.

  3. Prints the number of modified documents.

const clientUpdates = [{
namespace: "sample_mflix.movies",
name: "updateMany",
filter: {
rated: "PG-13"
},
update: {
$set: {
rated: "PG-13 Updated",
genre: "Updated Genre"
}
},
upsert: false
}, {
namespace: "sample_mflix.users",
name: "updateOne",
filter: {
name: "Jon Snow"
},
update: {
$set: {
name: "Aegon Targaryen",
email: "targaryen@example.com"
}
},
upsert: false
}];
const clientUpdateRes = await client.bulkWrite(clientUpdates);
console.log(`Modified documents: ${clientUpdateRes.modifiedCount}`);
Modified documents: 2320

To perform a bulk delete operation, create a bulk operation model for each delete operation. Then, pass a list of these models to the bulkWrite() method.

This section describes how to perform the following types of bulk operations:

To perform a bulk delete operation on your collection, create a DeleteOneModel or DeleteManyModel for each operation. Then, call the bulkWrite() method on your collection and pass an array of models as a parameter. A DeleteOneModel deletes only one document that matches a filter, while a DeleteManyModel deletes all documents that match a filter.

The following table describes the fields you can set in a DeleteOneModel or DeleteManyModel:

Field
Description

filter

The filter that matches one or more documents you want to delete. When specified in a DeleteOneModel, only the first matching document will be deleted. When specified in a DeleteManyModel, all matching documents will be deleted.
Type: Document

collation

(Optional) The collation to use when sorting results. To learn more about collations, see the Collation section of the Configure CRUD Operations guide.
Type: Object

hint

(Optional) The index to use for the operation. To learn more about indexes, see the Indexes on Collections guide.
Type: String or Object

This example performs the following actions:

  1. Specifies a DeleteOneModel and a DeleteManyModel instance in an array. These models contain instructions to delete documents in the movies collection.

  2. Calls the bulkWrite() method on the movies collection and passes an array of models as a parameter.

  3. Prints the number of deleted documents.

const deleteOperations = [{
deleteOne: {
filter: {
title: "Dunkirk"
}
}
}, {
deleteMany: {
filter: {
rated: "R"
}
}
}];
const deleteResult = await movies.bulkWrite(deleteOperations);
console.log(`Deleted documents: ${deleteResult.deletedCount}`);
Deleted documents: 5538

To perform a bulk delete operation across multiple collections or databases, create a ClientBulkWriteModel for each operation. Then, call the bulkWrite() method on your client and pass an array of models as a parameter.

The following table describes the fields you can set in a ClientBulkWriteModel to specify a delete operation:

Field
Description

namespace

The namespace in which to delete a document.
Type: String

name

The operation you want to perform. For delete operations, set this field to "deleteOne" or "deleteMany".
Type: String

filter

The filter that matches one or more documents you want to delete. If you set the model name to "deleteOne", only the first matching document is deleted. If you set name to "deleteMany", all matching documents are deleted.
Type: Document

hint

(Optional) The index to use for the operation. To learn more about indexes, see the Indexes on Collections guide.
Type: Document or String

collation

(Optional) The collation to use when sorting results. To learn more about collations, see the Collation section of the Configure CRUD Operations guide.
Type: Document

This example performs the following actions:

  1. Specifies two ClientBulkWriteModel instances in an array. The first model specifies a delete many operation on the movies collection, and the second model specifies a delete one operation on the users collection.

  2. Calls the bulkWrite() method on a client and passes an array of models as a parameter.

  3. Prints the number of modified documents.

const clientDeletes = [{
namespace: "sample_mflix.movies",
name: "deleteMany",
filter: {
rated: "R"
}
}, {
namespace: "sample_mflix.users",
name: "deleteOne",
filter: {
email: "emilia_clarke@gameofthron.es"
}
}];
const clientDeleteRes = await client.bulkWrite(clientDeletes);
console.log(`Deleted documents: ${clientDeleteRes.deletedCount}`);
Deleted documents: 5538

The Collection.bulkWrite() method returns a BulkWriteResult object, which provides information about your bulk operation.

The following tables describes the fields of a BulkWriteResult object:

Field
Description

insertedCount

The number of inserted documents

matchedCount

The number of matched documents

modifiedCount

The number of updated documents

upsertedCount

The number of upserted documents

deletedCount

The number of deleted documents

The MongoClient.bulkWrite() method returns a ClientBulkWriteResult object, which includes information about the client bulk write operation.

The following tables describes the fields of a ClientBulkWriteResult object:

Field
Description

acknowledged

A boolean value indicating whether the bulk write was acknowledged

insertedCount

The number of inserted documents

matchedCount

The number of matched documents

modifiedCount

The number of updated documents

upsertedCount

The number of upserted documents

deletedCount

The number of deleted documents

insertResults

The results of each individual successful insert operation

updateResults

The results of each individual successful update operation

deleteResults

The results of each individual successful delete operation

If any bulk write operations called on a collection are unsuccessful, the Node.js driver throws a MongoBulkWriteError and does not perform any further operations if the ordered option is set to true. If ordered is set to false, it will attempt to continue with subsequent operations.

Tip

To learn more about ordered and unordered bulk operations, see the Ordered vs Unordered Operations section in the Bulk Write guide from the MongoDB Server manual.

A MongoBulkWriteError object contains the following properties:

Property
Description

message

The error message.
Type: String

writeErrors

An array of errors that occurred during the bulk write operation.
Type: BulkWriteError[]

writeConcernErrors

Write concern errors that occurred during execution of the bulk write operation.
Type: WriteConnectionError[]

result

The results of any successful operations performed before the exception was thrown.
Type: BulkWriteResult[]

err

The underlying error object, which may contain more details.
Type: Error

If any bulk write operations called on your client are unsuccessful, the Node.js driver generates a MongoClientBulkWriteError. By default, the driver does not perform any subsequent operations after encountering an error. If you pass the ordered option to the bulkWrite() method and set it to false, the driver continues to attempt the remaining operations.

A MongoClientBulkWriteError object contains the following properties:

Property
Description

writeConcernErrors

An array of documents specifying each write concern error.
Type: Document[]

writeErrors

An map of errors that occurred during individual write operations.
Type: Map<number, ClientBulkWriteError>

partialResult

The partial result of the client bulk write that reflects the operation's progress before the error.
Type: ClientBulkWriteResult

Note

Example Setup

This example connects to an instance of MongoDB by using a connection URI. To learn more about connecting to your MongoDB instance, see the Connect to MongoDB guide. This example also uses the movies collection in the sample_mflix database included in the Atlas sample datasets. You can load them into your database on the free tier of MongoDB Atlas by following the Get Started with Atlas Guide.

The following code is a complete, standalone file that performs a bulk write operation on the theaters collection in the sample_mflix database. The operations parameter includes examples of insertOne, updateMany, and deleteOne write operations:

1// Bulk write operation
2
3// Import MongoClient from the MongoDB node driver package
4const { MongoClient } = require("mongodb");
5
6// Replace the uri string with your MongoDB deployment's connection string
7const uri = "<connection string uri>";
8
9const client = new MongoClient(uri);
10
11async function run() {
12 try {
13 const database = client.db("sample_mflix");
14 const theaters = database.collection("theaters");
15
16 // Insert a new document into the "theaters" collection
17 const result = await theaters.bulkWrite([
18 {
19 insertOne: {
20 document: {
21 location: {
22 address: {
23 street1: "3 Main St.",
24 city: "Anchorage",
25 state: "AK",
26 zipcode: "99501",
27 },
28 },
29 },
30 },
31 },
32 {
33 insertOne: {
34 document: {
35 location: {
36 address: {
37 street1: "75 Penn Plaza",
38 city: "New York",
39 state: "NY",
40 zipcode: "10001",
41 },
42 },
43 },
44 },
45 },
46 {
47 // Update documents that match the specified filter
48 updateMany: {
49 filter: { "location.address.zipcode": "44011" },
50 update: { $set: { is_in_ohio: true } },
51 upsert: true,
52 },
53 },
54 {
55 // Delete a document that matches the specified filter
56 deleteOne: { filter: { "location.address.street1": "221b Baker St" } },
57 },
58 ]);
59 // Log the result of the bulk write operation
60 console.log(result);
61 } finally {
62 // Close the database connection when the operations are completed or if an error occurs
63 await client.close();
64 }
65}
66run().catch(console.dir);
1import { MongoClient } from "mongodb";
2
3// Replace the uri string with your MongoDB deployment's connection string.
4const uri = "<connection string uri>";
5
6const client = new MongoClient(uri);
7
8interface Address {
9 street1: string;
10 city: string;
11 state: string;
12 zipcode: string;
13}
14
15interface Theater {
16 location: { address: Address };
17 is_in_ohio?: boolean;
18}
19
20async function run() {
21 try {
22 const database = client.db("sample_mflix");
23 const theaters = database.collection<Theater>("theaters");
24
25 const result = await theaters.bulkWrite([
26 {
27 insertOne: {
28 document: {
29 location: {
30 address: {
31 street1: "3 Main St.",
32 city: "Anchorage",
33 state: "AK",
34 zipcode: "99501",
35 },
36 },
37 },
38 },
39 },
40 {
41 insertOne: {
42 document: {
43 location: {
44 address: {
45 street1: "75 Penn Plaza",
46 city: "New York",
47 state: "NY",
48 zipcode: "10001",
49 },
50 },
51 },
52 },
53 },
54 {
55 updateMany: {
56 // Important: You lose type safety when you use dot notation in queries
57 filter: { "location.address.zipcode": "44011" },
58 update: { $set: { is_in_ohio: true } },
59 upsert: true,
60 },
61 },
62 {
63 deleteOne: {
64 filter: { "location.address.street1": "221b Baker St" },
65 },
66 },
67 ]);
68
69 console.log(result);
70 } finally {
71 await client.close();
72 }
73}
74run().catch(console.dir);

Running the preceding example results in the following output:

BulkWriteResult {
insertedCount: 2,
matchedCount: 1,
modifiedCount: 1,
deletedCount: 0,
upsertedCount: 0,
upsertedIds: {},
insertedIds: {
'0': new ObjectId("..."),
'1': new ObjectId("...")
}
}

To learn more about bulk operations, see Bulk Write Operations in the MongoDB Server manual.

To learn more about any of the methods or types discussed in this guide, see the following API documentation:

Back

Delete Documents