0
import mongoengine

class MyLog(mongoengine.EmbeddedDocument):
    text = mongoengine.StringField()

class Server(mongoengine.DynamicDocument):
    name = mongoengine.StringField()
    status = mongoengine.StringField()
    text_list = mongoengine.ListField(mongoengine.EmbeddedDocumentField(MyLog))

Server.objects.all()默认情况下,查询集不包含text_list字段的值。我必须这样做 - (获取text_list查询集中每个对象的字段值。

for s in Server.objects.all():
    print s.text_list

在我的情况/场景中,我不能这样做,我的意思是我必须在查询集本身中获取所有数据(或者换句话说,我需要一个查询集,它也可以在不使用的情况下为我提供所有嵌套的详细信息obj.text_list

例如

进一步在 mongo shell - db.server.find()包括所有嵌套的嵌入式文档。

{ 
  '_id': ObjectId("272742942qbe5451b4f4b9e7"),
  'name':'nm',
  'status': 'st',
  'text_list': [
       {# here it's including embedded model's info too, no need to make extra query, looking for similar query in mongoengine orm
         'text': 'done'
      }
  ]
}

我们如何在 mongoengine 中使用 orm 或 raw_query 做到这一点。

to_json()我可以通过使用方法在mongoengine orm中解决这个问题

json.loads(queryset.to_json())

Server.objects.all().to_json() 返回一个包含嵌入式模型信息的结果,但这在对数百万个文档使用分页时效率不高,我的意思是在这种情况下,mongo 将尝试将所有对象转换为 to_json。

4

1 回答 1

0

如果你想使用flask-mongoengine对查询集的结果进行分页,你应该简单地使用以下paginate方法Queryset

# Paginate through todo
def view_todos(page=1):
    paginated_todos = Todo.objects.paginate(page=page, per_page=10)

在这里您可以找到有关模板部分和其他可用功能的更多信息。

于 2016-05-05T13:14:24.407 回答