如何在pymongo中禁用'_id'

时间:2012-12-10 20:44:00

标签: python mongodb primary-key pymongo

我刚开始学习mongodb,但还不知道很多。

所以我的代码:

#! /usr/bin/env python2.7

import pymongo
import datetime

class AccountsDB():
    def __init__(self):
        self.store_info()

    def store_info(self):
        try:
            conn = pymongo.Connection('localhost', 27017)
            db_name = 'accountsdb'
            coll_name = 'user_info'

            db = conn[db_name]
            coll = db[coll_name]

            print "Successfully connected to '%s'" % db_name

            for i in xrange(20):
                post = {
                    'f_name' : 'Sergey',
                    'l_name' : 'Ivanov',
                    'number' : '777-9-777',
                    'user_id': i
                }
                coll.insert(post)

            print "Done"
        except:
            print "Can't connect to the database"


if __name__ == "__main__":
    acc = AccountsDB()

它给了我:

> db.user_info.find()
{ "_id" : ObjectId("50c64872bdbff34435192a94"), "l_name" : "Ivanov", "f_name" : "Sergey", "user_id" : 0, "number" : "777-9-777" }
{ "_id" : ObjectId("50c64872bdbff34435192a95"), "l_name" : "Ivanov", "f_name" : "Sergey", "user_id" : 1, "number" : "777-9-777" }
{ "_id" : ObjectId("50c64872bdbff34435192a96"), "l_name" : "Ivanov", "f_name" : "Sergey", "user_id" : 2, "number" : "777-9-777" }
{ "_id" : ObjectId("50c64872bdbff34435192a97"), "l_name" : "Ivanov", "f_name" : "Sergey", "user_id" : 3, "number" : "777-9-777" }
{ "_id" : ObjectId("50c64872bdbff34435192a98"), "l_name" : "Ivanov", "f_name" : "Sergey", "user_id" : 4, "number" : "777-9-777" }
{ "_id" : ObjectId("50c64872bdbff34435192a99"), "l_name" : "Ivanov", "f_name" : "Sergey", "user_id" : 5, "number" : "777-9-777" }

and so on....

但是我想摆脱'_id'并使用'user_id'作为我的主键。我很确定它可以做到,但不知道如何。

2 个答案:

答案 0 :(得分:1)

我很确定答案是否定的,你不能禁用“_id”。为什么? 只需看看source code of pymongo即可。查看collection.py并搜索“_id”。

嗯,我认为这可以通过猴子补丁完成,但它可以通过黑暗魔法完成。只是一个想法,我不推荐猴子修补。这就是为什么我的答案是否定的:(

答案 1 :(得分:1)

这样做:

post = {
            'f_name' : 'Sergey',
            'l_name' : 'Ivanov',
            'number' : '777-9-777',
            '_id': i
}

使用mongoDB,您只需使用“_id”作为值的键,它将使用您提供的值而不是自动生成值。

或者,只需在user_id上创建另一个索引并将其标记为“唯一”

db.collection.createIndex({"user_id":1}, {unique:true})