Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/348.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 基于Django中聚合结果的额外列_Python_Mysql_Django - Fatal编程技术网

Python 基于Django中聚合结果的额外列

Python 基于Django中聚合结果的额外列,python,mysql,django,Python,Mysql,Django,我有一个表存储KLine信息,包括安全id、最大/最小价格和日期,并希望计算特定时期内每个安全的收益。这是我的函数 def get_rising_rate(start, end): return models.KLine.objects.\ filter(start_time__gt=start). \ filter(start_time__lt=end).\ values("security__id").\

我有一个表存储KLine信息,包括安全id、最大/最小价格和日期,并希望计算特定时期内每个安全的收益。这是我的函数

def get_rising_rate(start, end):
    return models.KLine.objects.\
            filter(start_time__gt=start). \
            filter(start_time__lt=end).\
            values("security__id").\
            annotate(min_price=django_models.Min("min_price_in_cent"),
                      max_price=django_models.Max("max_price_in_cent")).\
            extra(select={"gain": "max_price_in_cent/min_price_in_cent"})
            order_by("gain")
但我得到了以下错误:

django.db.utils.OperationalError: (1247, "Reference 'max_price' not supported (reference to group function)")
我可以使用原始SQL进行查询,如

SELECT
`security_id`,
`min_price`,
`max_price`,
`max_price`/`min_price` AS gain
FROM(
SELECT
`security_id`, 
MIN(`min_price_in_cent`) AS `min_price`, 
MAX(`max_price_in_cent`) AS `max_price`
FROM `stocks_kline` 
WHERE `start_time` > '2014-12-31 16:00:00' AND `start_time` < '2015-12-31 16:00:00'
GROUP BY `security_id`
) AS A
ORDER BY gain DESC
但我想知道是否有更为django的方法来完成它。我搜索了django join queryset,django queryset作为派生表,但找不到解决方案

提前谢谢。

你能试试这个吗:

    def get_rising_rate(start, end):
        return models.KLine.objects.\
                filter(start_time__gt=start). \
                filter(start_time__lt=end).\
                values("security_id").\
                annotate(min_price=django_models.Min("min_price_in_cent"),
                          max_price=django_models.Max("max_price_in_cent")).\
                extra(select={"gain": "max(max_price_in_cent)/min(min_price_in_cent)"})
                order_by("gain")

这是你所有的代码吗?看起来你指的是其他地方的max_price。