gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 22:49:47 26 4
gpt4 key购买 nike

我有一张表存储 KLine 信息,包括证券 ID、最大/最小价格和日期,我想计算特定时期内每种证券的 yield 。这是我的功能

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 as derived tables”,但找不到解决方案。

提前致谢。

最佳答案

你能试试这个吗:

    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")

关于python - 基于 Django 中聚合结果的额外列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28505669/

26 4 0
文章推荐: c# - 在 .NET 中的编译时检查引用/类型是否存在
文章推荐: python - ** 或 pow() 不支持的操作数类型 : 'method' and 'int'
文章推荐: c# - Dynamic Linq - 在运行时设置 orderby 表达式类型
文章推荐: python - BeautifulSoup - 如何从 html 类中获取所有
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com