Đối với điều này, hãy sử dụng upsert và multi trong MongoDB -
Nâng cấp - Nếu được đặt thành true, hãy tạo tài liệu mới khi không có tài liệu nào phù hợp với tiêu chí truy vấn. Giá trị mặc định là false, giá trị này không chèn tài liệu mới khi không tìm thấy kết quả phù hợp nào.
Đa - f được đặt thành true, cập nhật nhiều tài liệu đáp ứng tiêu chí truy vấn. Nếu được đặt thành false, hãy cập nhật một tài liệu. Giá trị mặc định là false.
Hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -
> db.demo479.insertOne({"DueDate":new ISODate("2020-01-10"),"Name":"Chris"});{ "acknowledged" : true, "insertedId" : ObjectId("5e820733b0f3fa88e2279094") } > db.demo479.insertOne({"Name":"David"});{ "acknowledged" : true, "insertedId" : ObjectId("5e820748b0f3fa88e2279095") } > db.demo479.insertOne({"DueDate":new ISODate("2019-12-31"),"Name":"Bob"});{ "acknowledged" : true, "insertedId" : ObjectId("5e82075fb0f3fa88e2279096") } > db.demo479.insertOne({"Name":"Carol"});{ "acknowledged" : true, "insertedId" : ObjectId("5e820767b0f3fa88e2279097") }
Hiển thị tất cả các tài liệu từ một bộ sưu tập với sự trợ giúp của phương thức find () -
> db.demo479.find();
Điều này sẽ tạo ra kết quả sau -
{ "_id" : ObjectId("5e820733b0f3fa88e2279094"), "DueDate" : ISODate("2020-01- 10T00:00:00Z"), "Name" : "Chris" } { "_id" : ObjectId("5e820748b0f3fa88e2279095"), "Name" : "David" } { "_id" : ObjectId("5e82075fb0f3fa88e2279096"), "DueDate" : ISODate("2019-12- 31T00:00:00Z"), "Name" : "Bob" } { "_id" : ObjectId("5e820767b0f3fa88e2279097"), "Name" : "Carol" }
Sau đây là truy vấn để chỉ thêm trường dấu thời gian nếu nó không có -
> db.demo479.update({DueDate:{$exists:false}}, {$set : {"DueDate":new Date}}, {upsert:false, multi:true}); WriteResult({ "nMatched" : 2, "nUpserted" : 0, "nModified" : 2 })
Hiển thị tất cả các tài liệu từ một bộ sưu tập với sự trợ giúp của phương thức find () -
> db.demo479.find();
Điều này sẽ tạo ra kết quả sau -
{ "_id" : ObjectId("5e820733b0f3fa88e2279094"), "DueDate" : ISODate("2020-01- 10T00:00:00Z"), "Name" : "Chris" } { "_id" : ObjectId("5e820748b0f3fa88e2279095"), "Name" : "David", "DueDate" : ISODate("2020-03-30T14:52:29.656Z") } { "_id" : ObjectId("5e82075fb0f3fa88e2279096"), "DueDate" : ISODate("2019-12- 31T00:00:00Z"), "Name" : "Bob" } { "_id" : ObjectId("5e820767b0f3fa88e2279097"), "Name" : "Carol", "DueDate" : ISODate("2020-03-30T14:52:29.656Z") }