gpt4 book ai didi

sqlite - 获取每组中列值的中位数

转载 作者:行者123 更新时间:2023-12-03 18:11:57 30 4
gpt4 key购买 nike

我有一个包含user_id,movie_id,等级的表。这些均为INT,额定值范围为1-5。

我想获得中位数评分,并按user_id进行分组,但是这样做有些麻烦。

目前,我的代码是:

SELECT AVG(rating)
FROM (SELECT rating
FROM movie_data
ORDER BY rating
LIMIT 2 - (SELECT COUNT(*) FROM movie_data) % 2
OFFSET (SELECT (COUNT(*) - 1) / 2
FROM movie_data));


但是,这似乎返回所有等级的中间值。如何按user_id进行分组,以便查看每个用户的中位数评分?

最佳答案

以下给出了所需的中位数:

DROP TABLE IF EXISTS movie_data2;
CREATE TEMPORARY TABLE movie_data2 AS
SELECT user_id, rating FROM movie_data order by user_id, rating;

SELECT a.user_id, a.rating FROM (
SELECT user_id, rowid, rating
FROM movie_data2) a JOIN (
SELECT user_id, cast(((min(rowid)+max(rowid))/2) as int) as midrow FROM movie_data2 b
GROUP BY user_id
) c ON a.rowid = c.midrow
;


逻辑很简单,但是代码并未美化。给予鼓励或评论,我会改善它。简而言之,诀窍是使用SQLite的 rowid

关于sqlite - 获取每组中列值的中位数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35400152/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com