您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

如何在mongoengine中获取ReferenceField数据?

如何在mongoengine中获取ReferenceField数据?

当前不直接支持功能,因为MongoEngine仅支持mongodb的扩展json语法。

mongoengine所做的所有工作都是使用pymongojson_utils来转储数据。没有理由不能明确使用它,例如:

    from bson import json_util

    class In@R_11_2419@(db.Document):
        from_user    = db.ReferenceField(User, required=True)
        subject      = db.StringField(max_length=255, required=True)
        created_at   = db.DateTimeField(default=datetime.Now)
        messages     = db.ListField(db.EmbeddedDocumentField(Message))


        def to_json(self):
            data = self.to_mongo() // get the pymongo representation of the document
            data["from_user"] = {"User": {"username": self.from_user.username}}
            return json_util.dumps(data)

            User.drop_collection()

    ...

    In@R_11_2419@.drop_collection()

    ross = User(username="Ross").save()
    In@R_11_2419@(from_user=ross, subject="Mongoengine should make json easier").save()

    doc = In@R_11_2419@.objects.only('from_user', 'subject', 'created_at').get()
    print doc.to_json()

    {"_id": {"$oid": "538c3d71c3d384172fe35393"}, 
     "from_user": {"User": {"username": "Ross"}}, 
     "subject": "Mongoengine should make json easier", 
     "created_at": {"$date": 1401703297198}, "messages": []}

带有自定义查询集的示例:

   from bson import json_util

    class CustomQuerySet(QuerySet):
         def to_json(self):
            return "[%s]" % (",".join([doc.to_json() for doc in self]))

    class In@R_11_2419@(Document):
        from_user    = ReferenceField(User, required=True)
        subject      = StringField(max_length=255, required=True)
        created_at   = DateTimeField(default=datetime.Now)
        messages     = ListField(EmbeddedDocumentField(Message))

        Meta = {'queryset_class': CustomQuerySet}

        def to_json(self):
            data = self.to_mongo()
            data["from_user"] = {"User": {"username": self.from_user.username}}
            return json_util.dumps(data)

  ...
  ipdb> In@R_11_2419@.objects.only('from_user', 'subject', 'created_at').to_json()
        '[{"_id": {"$oid": "538d84cbc3d3843eeeb5dbbe"}, 
           "from_user": {"User": {"username": "Ross"}}, 
           "subject": "Mongoengine should make json easier", 
           "created_at": {"$date": 1401787099246}, "messages": []}]'
mongodb 2022/1/1 18:39:15 有455人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶