Mongoengine中的“QuerySet”对象究竟是什么?

时间:2013-03-01 04:00:59

标签: python list class mongodb mongoengine

根据Mongoengine API指南(http://mongoengine-odm.readthedocs.org/en/latest/apireference.html):

class mongoengine.queryset.QuerySet(document, collection)

是" 从查询返回的一组结果。包装MongoDB游标,提供Document对象作为结果。"

当我在我的解释器中使用type()检查QuerySet对象时,它表示QuerySet对象是<class 'mongoengine.queryset.QuerySet'>,与API指南一致。

我很困惑,因为为了实际访问QuerySet实例中的各个Mongoengine Document对象,我必须使用像[0]这样的索引方法(对于第一个Document对象)或[2](对于第三个Document对象)See this SO question about slicing a QuerySet。有趣的是,您还可以在QuerySet实例上调用len()

即使QuerySet是一个类对象,为什么它看起来像列表对象?据我所知,它并不是从UserList继承而且没有data属性。任何帮助将不胜感激。

感谢。

修改

感谢您的建议@isbadawi。这很有帮助。 QuerySet类对象确实包含__getitem__方法,正如您的链接所示,该方法大致相当于&#34;索引(例如x.__getitem__(i)大致相当于x[i])。因此,如果QuerySet通过__getitem__模拟列表类,那么实际的Document对象存储在类中的哪个位置?在一个属性?这是我的翻译中dir(QuerySet)的输出:

> ['_QuerySet__already_indexed', '_QuerySet__dereference', '__call__', '__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', '__getitem__', '__hash__', '__init__', '__iter__', '__len__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', '_as_pymongo', '_as_pymongo_coerce', '_build_index_spec', '_class_check', '_collection', '_collection_obj', '_cursor', '_cursor_args', '_cursor_obj', '_dereference', '_document', '_ensure_indexes', '_fields_to_dbfields', '_get_as_pymongo', '_get_scalar', '_hint', '_initial_query', '_item_frequencies_exec_js', '_item_frequencies_map_reduce', '_iter', '_limit', '_loaded_fields', '_lookup_field', '_mongo_query', '_ordering', '_query', '_query_obj', '_reset_already_indexed', '_scalar', '_skip', '_slave_okay', '_snapshot', '_sub_js_fields', '_timeout', '_transform_query', '_transform_update', '_translate_field_name', '_where_clause', 'all', 'all_fields', 'as_pymongo', 'average', 'clone', 'count', 'create', 'delete', 'distinct', 'ensure_index', 'exclude', 'exec_js', 'explain', 'fields', 'filter', 'first', 'get', 'get_or_create', 'hint', 'in_bulk', 'insert', 'item_frequencies', 'limit', 'map_reduce', 'next', 'only', 'order_by', 'rewind', 'scalar', 'select_related', 'skip', 'slave_okay', 'snapshot', 'sum', 'timeout', 'update', 'update_one', 'values_list', 'where', 'with_id']

1 个答案:

答案 0 :(得分:6)

the code QuerySet中所见,是对pymongo cursor的一种抽象。因此QuerySet内没有存储空间。

当您致电len() QuerySet.__len__时,会调用魔法方法,该方法会返回self.count()的结果,该结果会询问光标的计数。

等等。 QuerySet.__getitem__向光标询问相应的项目,QuerySet.first执行相同的操作。

我强烈建议您在怀疑内部如何实施时查看代码。