中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

DB2行列轉置的行轉列是怎樣的

發布時間:2021-11-30 11:22:30 來源:億速云 閱讀:597 作者:柒染 欄目:數據庫

DB2行列轉置的行轉列是怎樣的,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

建表,并insert 2行數據
CREATE TABLE SalesAgg(year INTEGER, q1 INTEGER, q2 INTEGER, q3 INTEGER, q4 INTEGER);
insert into SalesAgg values(2004,20,30,15,10);
insert into SalesAgg values(2005,18,40,12,27);

Select * from SalesAgg

 YEAR Q1 Q2 Q3 Q4
 ---- -- -- -- --
 2004 20 30 15 10
 2005 18 40 12 27

想把數據轉成下面的樣子
 YEAR QUARTER RESULTS
 ---- ------- -------
 2004       1      20
 2004       2      30
 2004       3      15
 2004       4      10
 2005       1      18
 2005       2      40
 2005       3      12
 2005       4      27

列轉換成行的SQL
SELECT Year, Quarter, Results
FROM SalesAgg AS S,
LATERAL(VALUES(1, S.q1),
(2, S.q2),
(3, S.q3),
(4, S.q4))
AS Q(Quarter, Results); LATERAL的地方可以換成TABLE,結果一樣,其目的都是通過VALUES值來組合成一個臨時表Q在SQL中使用
SELECT Year, Quarter, Results
FROM SalesAgg AS S,
TABLE(VALUES(1, S.q1),
(2, S.q2),
(3, S.q3),
(4, S.q4))
AS Q(Quarter, Results);

另外一個使用TABLE的例子
SELECT id ANSWER
    ,salary AS sal
    ,comm AS com
    ,combo
    ,typ
FROM staff
    ,TABLE (
        VALUES (
            salary
            ,'SAL'
            )
            ,(
            comm
            ,'COM'
            )
        ) AS tab(combo, typ)
WHERE id < 40
ORDER BY id
    ,typ;                   

行轉列使用示例

CREATE OR REPLACE PROCEDURE DB2INST1.TEST(OUT out_msg VARCHAR(4000))
SPECIFIC DB2INST1.TEST
MODIFIES SQL DATA
NOT DETERMINISTIC
NULL CALL
LANGUAGE SQL EXTERNAL ACTION
INHERIT SPECIAL REGISTERS
BEGIN
    DECLARE v_col1s VARCHAR(4000);
    DECLARE v_sql VARCHAR(4000);
    SELECT SUBSTR(XMLCAST(XMLGROUP(',' || col1 AS a ORDER BY col1) as varchar(4000)),2) into v_col1s FROM aaa;
    SET out_msg = 'SELECT * FROM aaa where col1 in (' || TRIM(v_col1s) || ')';     

看完上述內容,你們掌握DB2行列轉置的行轉列是怎樣的的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

db2
AI

修文县| 柯坪县| 满洲里市| 巴东县| 山丹县| 墨竹工卡县| 德庆县| 罗甸县| 桂林市| 大埔县| 开封市| 乌审旗| 曲沃县| 顺义区| 米泉市| 平度市| 河西区| 永定县| 宜宾县| 阿勒泰市| 四子王旗| 汝阳县| 安仁县| 淳化县| 江安县| 什邡市| 修武县| 顺昌县| 黑河市| 阿克陶县| 石屏县| 夹江县| 高唐县| 孙吴县| 保定市| 丹寨县| 土默特左旗| 门源| 阳春市| 高淳县| 商洛市|