查一个表中近12个月数据,利用ORACLE列转行语句功能,备忘

SELECT DISTINCT pk_month ,BEFORE_X,MONTH_VALUE
  FROM (SELECT PERSON_NUMBER,    pk_month,pk_month "before_0",
    TO_CHAR (
        "ADD_MONTHS" (
            TO_DATE (pk_month, 'yyyy-mm'),
            - 1
        ),
        'yyyy-mm'
    ) "before_1",
    TO_CHAR (
        "ADD_MONTHS" (
            TO_DATE (pk_month, 'yyyy-mm'),
            - 2
        ),
        'yyyy-mm'
    ) "before_2",
    TO_CHAR (
        "ADD_MONTHS" (
            TO_DATE (pk_month, 'yyyy-mm'),
            - 3
        ),
        'yyyy-mm'
    ) "before_3",
    TO_CHAR (
        "ADD_MONTHS" (
            TO_DATE (pk_month, 'yyyy-mm'),
            - 4
        ),
        'yyyy-mm'
    ) "before_4",
    TO_CHAR (
        "ADD_MONTHS" (
            TO_DATE (pk_month, 'yyyy-mm'),
            - 5
        ),
        'yyyy-mm'
    ) "before_5",
    TO_CHAR (
        "ADD_MONTHS" (
            TO_DATE (pk_month, 'yyyy-mm'),
            - 6
        ),
        'yyyy-mm'
    ) "before_6",
    TO_CHAR (
        "ADD_MONTHS" (
            TO_DATE (pk_month, 'yyyy-mm'),
            - 7
        ),
        'yyyy-mm'
    ) "before_7",
    TO_CHAR (
        "ADD_MONTHS" (
            TO_DATE (pk_month, 'yyyy-mm'),
            - 8
        ),
        'yyyy-mm'
    ) "before_8",
    TO_CHAR (
        "ADD_MONTHS" (
            TO_DATE (pk_month, 'yyyy-mm'),
            - 9
        ),
        'yyyy-mm'
    ) "before_9",
    TO_CHAR (
        "ADD_MONTHS" (
            TO_DATE (pk_month, 'yyyy-mm'),
            - 10
        ),
        'yyyy-mm'
    ) "before_10",
    TO_CHAR (
        "ADD_MONTHS" (
            TO_DATE (pk_month, 'yyyy-mm'),
            - 11
        ),
        'yyyy-mm'
    ) "before_11"
          FROM FACT_LABOR_EMPLOYMENT_COUNT) UNPIVOT(MONTH_VALUE FOR BEFORE_X IN( "before_0",
                                                 "before_1",
"before_2",
"before_3",
"before_4",
"before_5",
"before_6",
"before_7",
"before_8",
"before_9",
"before_10",
"before_11")) ORDER BY 1,3

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值