簡體   English   中英

根據行的最大值選擇列名

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM