簡體   English   中英

從多列的一行中獲取SQL查詢結果

[英]Get SQL query results in a single row from multiple columns

我有一個帶有以下記錄的UPC表

SKU         ATTR_NAME       ATTR_VALUE
---------   ---------       ----------
38890630    COLOR           Black
38890630    DISC            Y
38890630    SIZE            8

我想要的輸出如下

SKU         COLOR     SIZE
---------   ------    ----
38890630    Black      8

我嘗試了多種方法,但無法獲得所需的輸出。 有人可以幫忙嗎?

您可以使用條件聚合:

select sku,
       max(case when attr_name = 'COLOR' then attr_value end) as color,
       max(case when attr_name = 'DISC' then attr_value end) as disc,
       max(case when attr_name = 'SIZE' then attr_value end) as size
from t
group by sku;

您可以使用PIVOT查詢:

WITH UPC_TABLE AS (
    SELECT 38890630 AS SKU, 'COLOR' AS ATTR_NAME, 'BLACK' AS ATTR_VALUE FROM DUAL
    UNION ALL SELECT 38890630 AS SKU, 'DISC' AS ATTR_NAME, 'Y' AS ATTR_VALUE FROM DUAL
    UNION ALL SELECT 38890630 AS SKU, 'SIZE' AS ATTR_NAME, '8' AS ATTR_VALUE FROM DUAL
)
SELECT * FROM 
     UPC_TABLE PIVOT (MAX(ATTR_VALUE) AS ATTR_VALUE FOR (ATTR_NAME) IN (
          'COLOR' AS COLOR
      ,   'DISC' AS DISC
      ,   'SIZE' AS SIZE_FIELD
     )

);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

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