[英]Select column names based on max value by row
我需要根据行的最大值选择列名。 我有雪花数据库表:
id cars_cat1 cars_cat2 cars_cat_3
a01 5 2 8
a02 6 1 5
a03 6 5 12
a04 3 9 1
ID 和许多带有计数的类别在哪里。 我需要带有类别名称的新列,其中计数为最大值。
输出:
id max_category
a01 cars_cat_3
a02 cars_cat1
a03 cars_cat_3
a04 cars_cat2
我尝试窗口函数......没有成功。
您可以在CASE
表达式中使用函数GREATEST()
:
SELECT id,
CASE GREATEST(cars_cat1, cars_cat2, cars_cat_3)
WHEN cars_cat1 THEN 'cars_cat1'
WHEN cars_cat2 THEN 'cars_cat2'
WHEN cars_cat3 THEN 'cars_cat3'
END max_category
FROM tablename
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.