
- MongoDB Tutorial
- MongoDB - Home
- MongoDB - Overview
- MongoDB - Advantages
- MongoDB - Environment
- MongoDB - Data Modeling
- MongoDB - Create Database
- MongoDB - Drop Database
- MongoDB - Create Collection
- MongoDB - Drop Collection
- MongoDB - Data Types
- MongoDB - Insert Document
- MongoDB - Query Document
- MongoDB - Update Document
- MongoDB - Delete Document
- MongoDB - Projection
- MongoDB - Limiting Records
- MongoDB - Sorting Records
- MongoDB - Indexing
- MongoDB - Aggregation
- MongoDB - Replication
- MongoDB - Sharding
- MongoDB - Create Backup
- MongoDB - Deployment
- MongoDB - Java
- MongoDB - PHP
- Advanced MongoDB
- MongoDB - Relationships
- MongoDB - Database References
- MongoDB - Covered Queries
- MongoDB - Analyzing Queries
- MongoDB - Atomic Operations
- MongoDB - Advanced Indexing
- MongoDB - Indexing Limitations
- MongoDB - ObjectId
- MongoDB - Map Reduce
- MongoDB - Text Search
- MongoDB - Regular Expression
- Working with Rockmongo
- MongoDB - GridFS
- MongoDB - Capped Collections
- Auto-Increment Sequence
- MongoDB Useful Resources
- MongoDB - Questions and Answers
- MongoDB - Quick Guide
- MongoDB - Useful Resources
- MongoDB - Discussion
Avoid duplicate entries in MongoDB?
To avoid duplicate entries in MongoDB, you can use createIndex(). The syntax is as follows −
db.yourCollectionName.createIndex({"yourFieldName":1},{unique:true});
Let us implement the above syntax. The query to avoid duplicate entries in MongoDB is a follows −
> db.avoidDuplicateEntriesDemo.createIndex({"UserName":1},{unique:true}); { "createdCollectionAutomatically" : true, "numIndexesBefore" : 1, "numIndexesAfter" : 2, "ok" : 1 }
Now insert some records in the above collection. The query to insert record is as follows −
> db.avoidDuplicateEntriesDemo.insertOne({"UserName":"John"}); { "acknowledged" : true, "insertedId" : ObjectId("5c90e1824afe5c1d2279d697") }
Here is the error whenever you try to insert the same record once again −
> db.avoidDuplicateEntriesDemo.insertOne({"UserName":"John"}); 2019-03-19T18:03:08.465+0530 E QUERY [js] WriteError: E11000 duplicate key error collection: test.avoidDuplicateEntriesDemo index: UserName_1 dup key: { : "John" } : WriteError({ "index" : 0, "code" : 11000, "errmsg" : "E11000 duplicate key error collection: test.avoidDuplicateEntriesDemo index: UserName_1 dup key: { : \"John\" }", "op" : { "_id" : ObjectId("5c90e1844afe5c1d2279d698"), "UserName" : "John" } }) 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
Let us insert another record. The query is as follows −
> db.avoidDuplicateEntriesDemo.insertOne({"UserName":"Carol"}); { "acknowledged" : true, "insertedId" : ObjectId("5c90e18d4afe5c1d2279d699") }
Display all documents from a collection with the help of find() method. The query is as follows −
> db.avoidDuplicateEntriesDemo.find();
The following is the output −
{ "_id" : ObjectId("5c90e1824afe5c1d2279d697"), "UserName" : "John" } { "_id" : ObjectId("5c90e18d4afe5c1d2279d699"), "UserName" : "Carol" }
- Related Articles
- How to remove duplicate entries by two keys in MongoDB?
- How to avoid inserting duplicate rows in MySQL?
- Delete duplicate alphanumeric entries from column data in SQL
- Program to remove duplicate entries in a list in Python
- MySQL UNIQUE declaration to avoid inserting duplicate values?
- Program to remove duplicate entries in a linked list in Python
- Suppressing duplicate entries in classical and ALV report in SAP ABAP
- Find duplicate records in MongoDB?
- Using recursion to remove consecutive duplicate entries from an array in JavaScript
- Using recursion to remove consecutive duplicate entries from an array - JavaScript
- Selecting the top occurring entries in MySQL from a table with duplicate values?
- Avoid MongoDB performance issues while using regex
- Efficient way to remove all entries from MongoDB?
- How to not allow duplicate entries to be entered a MySQL Table?
- MongoDB transaction & indexes for duplicate values

Advertisements