MongoEngine插入查询

时间:2015-09-21 04:40:33

标签: python mongodb flask mongodb-query mongoengine

我有一个模型User

class User(db.DynamicDocument):
    user_id = db.UUIDField(primary_key=True,required=True,default=uuid.uuid4)
    name = db.StringField(default='')
    phone = db.ListField(db.StringField,default=list)
    gcm_details = db.ListField(db.EmbeddedDocumentField('UserGCM'),default=list)

其中gcm_details是EmbeddedDocumentField,其详细信息如下: -

class UserGCM(db.EmbeddedDocument):
    gcm_key = db.StringField(default='')
    device_id = db.StringField(default='')

我按如下方式执行插入查询: -

name = 'something'
phone = ['12345678','456789']
gcm_obj = UserGCM(gcm_key=gcm_key,device_id=device_id)

user = User(name=name,push__phone=phone,push__gcm_details=gcm_obj).save()

这会得到保存。但是,当我在mongo shell中看到详细信息时,我会得到以下文档。

{
    "_id": BinData(3,
    "MjpPJaNTQ823WuA8BP47jQ=="),
    "parent_id": BinData(3,
    "Ig7LNNAVQzCbjYG2KXvQjw=="),
    "name": "something",
    "phone": [

    ],

    "gcm_details": [

    ],

    "push__phone": [
        "9999999999"
    ],
    "push__gcm_details": {
        "gcm_key": "string",
        "device_id": "string",
        "_cls": "UserGCM"
    }
}

注意空phonegcm_details字段,并添加了push__phonepush__gcm_details字段。这是怎么回事?

如果我这样做

user = User(name=name,phone=phone,gcm_details=gcm_obj).save()

不使用push__,会抛出错误说: -

TypeError: unbound method _validate() must be called with StringField instance as first argument (got unicode instance instead)

这是怎么回事?我做错了什么?

1 个答案:

答案 0 :(得分:1)

您的错误在这里:

  

phone = db.ListField( db.StringField ,默认=列表)

您应该使用StringField的实例,如下所示:

phone = db.ListField(db.StringField(), default=list)

然后你就可以做你想做的事了:

name = 'something'
phone = ['12345678', '456789']
gcm = UserGCM(gcm_key=gcm_key, device_id=device_id)
user = User(
    name=name,
    phone=phone,
    gcm_details=[gcm],
).save()