unique를 사용하고 TRUE로 설정하십시오. 인덱스를 생성하고 두 개의 열을 고유하게 설정하여 동일하게 구현합시다 -
>db.keepTwoColumnsUniqueDemo.createIndex({"StudentFirstName":1,"StudentLastName":1},{unique:true}); { "createdCollectionAutomatically" : true, "numIndexesBefore" : 1, "numIndexesAfter" : 2, "ok" : 1 }
이제 위 컬렉션에 문서를 삽입할 수 있습니다 -
>db.keepTwoColumnsUniqueDemo.insertOne({"StudentFirstName":"John","StudentLastName":"Smith","StudentAge":21}); { "acknowledged" : true, "insertedId" : ObjectId("5cd30fd7b64f4b851c3a13e5") } >db.keepTwoColumnsUniqueDemo.insertOne({"StudentFirstName":"John","StudentLastName":"Doe","StudentAge":23}); { "acknowledged" : true, "insertedId" : ObjectId("5cd30fe5b64f4b851c3a13e6") } >db.keepTwoColumnsUniqueDemo.insertOne({"StudentFirstName":"John","StudentLastName":"Smith","StudentAge":24}); 2019-05-08T22:50:42.803+0530 E QUERY [js] WriteError: E11000 duplicate key error collection: sample.keepTwoColumnsUniqueDemo index: StudentFirstName_1_StudentLastName_1 dup key: { : "John", : "Smith" } : WriteError({ "index" : 0, "code" : 11000, "errmsg" : "E11000 duplicate key error collection: sample.keepTwoColumnsUniqueDemo index: StudentFirstName_1_StudentLastName_1 dup key: { : \"John\", : \"Smith\" }", "op" : { "_id" : ObjectId("5cd30feab64f4b851c3a13e7"), "StudentFirstName" : "John", "StudentLastName" : "Smith", "StudentAge" : 24 } }) WriteError@src/mongo/shell/bulk_api.js:461:48 Bulk/mergeBatchResults@src/mongo/shell/bulk_api.js:841:49 Bulk/executeBatch@src/mongo/shell/bulk_api.js:906:13 Bulk/this.execute@src/mongo/shell/bulk_api.js:1150:21 DBCollection.prototype.insertOne@src/mongo/shell/crud_api.js:252:9 @(shell):1:1
위에서 두 개의 열을 고유하게 설정하고 이제 중복 값을 포함하려고 하므로 다음 오류가 표시됩니다. -
duplicate key error collection
다음은 find() 메서드를 사용하여 컬렉션의 모든 문서를 표시하는 쿼리입니다. -
> db.keepTwoColumnsUniqueDemo.find().pretty();
이것은 다음과 같은 출력을 생성합니다 -
{ "_id" : ObjectId("5cd30fd7b64f4b851c3a13e5"), "StudentFirstName" : "John", "StudentLastName" : "Smith", "StudentAge" : 21 } { "_id" : ObjectId("5cd30fe5b64f4b851c3a13e6"), "StudentFirstName" : "John", "StudentLastName" : "Doe", "StudentAge" : 23 }