11

我已经定义了类声明:

from mongoengine import *
class TickDataDocument(Document):
"""
"""
    instrument_id = StringField(max_length=10, unique=True, required=True)
    tick_data = ReferenceField(TickDocument)


class TickDocument(Document):
"""
"""
    price = DecimalField(precision=2, required=True) 
    volume = LongField(required=True)  
    turnover = DecimalField(precision=2, required=True)  
    update_time = DateTimeField(unique=True, required=True)

我想在某个时间段内查询 update_time。

 TickDataDocument.objects(instrument_id="fa1100").filter(tick_data__ update_time__lt =datetime.datetime(2013,9,3))

但我得到了错误:

mongoengine.errors.InvalidQueryError:无法在 mongoDB 中执行连接:tick_data__update_time

我怎么能找到五种解决方案来查询 mongoengine 中的内部引用字段。

4

2 回答 2

6

正如评论中所建议的,我分两个步骤(两个查询)执行此操作:

tick_docs = list(TickDocument.object(update_time__lt)=datetime.datetime(2013,9,3))

TickDataDocument.objects(instrument_id="fa1100").filter(tick_data__in=tick_docs)

如果有任何更简单的解决方案,我也很感兴趣。

于 2016-05-10T10:18:39.180 回答
0

您可以在 mongoengine中使用聚合方法并使用$lookup语法进行连接和查询,请注意使用聚合方法返回游标对象,而不是 QuerySet。

例子

TickDataDocument.objects().aggregate([
    {"$match":{"instrument_id":"fa1100"}},
    {"$lookup":{
        "from": TickDocument._get_collection_name(),
        "localField": "tick_data",
        "foreignField": "_id",
        "as": "tick"            
    }},
    {"$match":{
        "tick.update_time":{"$lt":datetime.datetime(2013,9,3)}
    }}
])
于 2021-02-12T13:35:04.533 回答