我刚开始学习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'作为我的主键。我很确定它可以做到,但不知道如何。
答案 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})