Exception in thread \"main\" com.mongodb.MongoException$DuplicateKey: { \"serverUsed\" : \"localhost/127.0.0.1:27017\" , \"err\" : \"E11000 duplicate key
Try calling myIdMapCollection.save(myObj);
instead of myIdMapCollection.insert(myObj);
The save
method, unlike insert
does upsert, meaning if a document contains _id
, it replaces that document.
My guess is that you had fetched the DBObject
using a cursor | query, had manipulated it, and you want to persist the changes. In that case, save
is the right way to do it.
So, when calling insert
the DBObject
is already associated with _id
, calling insert
thus fails, because you already have a document with that _id
in the collection, which should be unique (duplicate index error).
I found an answer on this page. I’m guessing your code looks something like this (greatly simplified)?:
doc = {}
for i in xrange(2):
doc['i'] = i
collection.insert(doc)
The problem is that PyMongo injects an _id field into the document, if the _id
field does not exist, before inserting it (_id
is always generated client side with 10gen drivers). That means that the first time through the loop _id
is added by the insert method. Since doc
is defined outside the loop, each subsequent pass through the loop uses the same value for _id
.
Solution:
for i in xrange(2): doc['i'] = i if '_id' in doc: del doc['_id'] collection.insert(doc)
from bson.objectid import ObjectId for i in xrange(2): doc['i'] = i doc['_id'] = ObjectId() collection.insert(doc)