ในการแทรกบันทึกใน MongoDB และหลีกเลี่ยงการซ้ำซ้อน ให้ใช้ “unique:true” ให้เราสร้างคอลเลกชันที่มีเอกสารก่อน
ที่นี่เรากำลังพยายามเพิ่มบันทึกที่ซ้ำกัน -
> db.insertWithoutDuplicateDemo.createIndex({"StudentFirstName":1},{ unique: true } ); { "createdCollectionAutomatically" : true, "numIndexesBefore" : 1, "numIndexesAfter" : 2, "ok" : 1 } > db.insertWithoutDuplicateDemo.insert({"StudentFirstName":"Chris"},{ upsert: true }); WriteResult({ "nInserted" : 1 }) > db.insertWithoutDuplicateDemo.insert({"StudentFirstName":"David"},{ upsert: true }); WriteResult({ "nInserted" : 1 }) > db.insertWithoutDuplicateDemo.insert({"StudentFirstName":"Chris"},{ upsert: true }); WriteResult({ "nInserted" : 0, "writeError" : { "code" : 11000, "errmsg" : "E11000 duplicate key error collection: test.insertWithoutDuplicateDemo index: StudentFirstName_1 dup key: { : \"Chris\" }" } }) > db.insertWithoutDuplicateDemo.insert({"StudentFirstName":"Bob"},{ upsert: true }); WriteResult({ "nInserted" : 1 })
ต่อไปนี้เป็นแบบสอบถามเพื่อแสดงเอกสารทั้งหมดจากคอลเลกชันโดยใช้วิธี find() -
> db.insertWithoutDuplicateDemo.find().pretty();
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -
{ "_id" : ObjectId("5e064405150ee0e76c06a054"), "StudentFirstName" : "Chris" } { "_id" : ObjectId("5e064410150ee0e76c06a055"), "StudentFirstName" : "David" } { "_id" : ObjectId("5e06441f150ee0e76c06a057"), "StudentFirstName" : "Bob" }