使用from_json制作的MongoEngine文档对象不保存

时间:2014-02-12 15:15:47

标签: python mongodb pymongo mongoengine flask-mongoengine

我正在尝试使用from_json方法构建一个文档对象。 object.save()不会抛出任何错误,但文档未插入mongo。

另一方面,如果我通过为每个字段分配值来制作对象,那么它可以正常工作。

我无法找到原因。以下是两种情况的代码。

from flask import Flask
from flask.ext.mongoengine import MongoEngine
import json, datetime

app = Flask(__name__)
app.config["MONGODB_SETTINGS"] = {'DB': 'test','host': 'localhost'}
app.config["SECRET_KEY"] = "mySecretKey"

db = MongoEngine(app)
class User(db.Document):
    user_id = db.StringField(max_length=16, primary_key = True)
    username = db.StringField(min_length=8)
    email = db.EmailField(required = True, unique = True)
    password = db.StringField(required = True)
    date_of_birth = db.DateTimeField()
    gender = db.StringField(choices = ('M', 'F'))

'''
    This one works. This will add a user in local mongodb(test)
'''
u1 = User()
u1.username = 'test12345'
u1.user_id = 'testid12345'
u1.email = 'test@test.com'
u1.password = 'testerpass'
u1.save()

'''
    This one doesn't works.
'''
u2 = User()
temp_json = {'username':'test2_12345','user_id':'testid2@12345','password':'testerpass2','email':'test2@test.com'}
u2 = u2.from_json(json.dumps(temp_json))
u2.save()

3 个答案:

答案 0 :(得分:12)

可以使用**kwargs初始化mongoengine文档对象。因此,我们可以通过以下方式实现from_json功能: -

obj_dict = {
    'key1' : 'value1',
    'key2' : 'value2'
}
user = User(**obj_dict) # User is a mongoengine document object

这对我有用。

答案 1 :(得分:2)

from_json()未保存的文档实例转换为JSON数据。 保存未保存的文档是使用参数force_insert=True

...
>>> User.objects
[<User: test1-12345>]
>>> u2.save()
>>> User.objects
[<User: test1-12345>]
>>> u2.save(force_insert=True)
>>> User.objects
[<User: test1-12345>, <User: test2-12345>]

但是,我的代码可以。

我不能在这里编码。 (我需要单元测试的夹具数据。)

我环境Django 1.6.5和mongoengine 0.8.7

>>> json_data1 = u1.to_json()
>>> User.objects.delete() # or User.drop_collection()
>>> User.objects
[]
>>>
...
# json_data1 to dump for pickle. Next load for pickle.
...
>>> u1 = User.from_json(json_data1)
>>> u1.save()
>>> User.objects
[]
>>> u1.save(force_insert=True)
>>> User.objects
[<User: test1-12345>]
>>>

force_insert=True只是尝试创建一个新文档。

每次使用force_insert=True都会创建一个新文档。

使用force_insert=False获取数据库中的文档。

答案 2 :(得分:-1)

您要将u2分配给from_json()的结果,并且丢失对原始用户对象的引用。

u2 = u2.from_json(...更改为u2.from_json(...