首先我的 django 模型是这样的:
class List(Document):
owner = ReferenceField('User')
name = StringField()
users = ListField(ReferenceField('User'))
created_at = DateTimeField(default=datetime.datetime.now)
在我添加了一个新提交的 is_cancelled 之后,现在是这样的:
class List(Document):
owner = ReferenceField('User')
name = StringField()
users = ListField(ReferenceField('User'))
created_at = DateTimeField(default=datetime.datetime.now)
is_cancelled = BooleanField(default = False)
我将 mongoengine 用于 django mongodb ORM。但是现在当我想进行过滤查询时:
List.objects.filter(is_cancelled=False)
returns []
我使用 django 对象将所有 is_cancelled 字段设置为 False:
for x in List.objects.all():
x.is_cancelled = False
x.save()
但是对于上面的查询,我仍然得到一个空列表。我正在寻找一个 django 对象的 is_cancelled 文件,我看到 is_cancelled = False
l = List.objects.all()[0]
l.is_cancelled
错误的
但是当我从 mongodb shell 看时。没有归档为 is_cancelled。
db.list.find()
{ "_cls" : "List", "_id" : ObjectId("4e8451598ebfa80228000000"), "_types" : [ "List" ],
"created_at" : ISODate("2011-09-29T16:24:28.781Z"), "name" : "listname", "users" : [
{
"$ref" : "user",
"$id" : ObjectId("4e79caf78ebfa80c00000001")
}, {
"$ref" : "user",
"$id" : ObjectId("4e79e4df8ebfa80b64000001")
}, {
"$ref" : "user",
"$id" : ObjectId("4e7aeb898ebfa80b64000001")
}, {
"$ref" : "user",
"$id" : ObjectId("4e79ce028ebfa80c00000004")
} ] }
如何修复此查询