zoukankan      html  css  js  c++  java
  • 行转列:SQL SERVER PIVOT与用法解释

    1创建一张临时表

    CREATE TABLE #week_income(
    week NVARCHAR(20) ,
    income INT
    )

    2向临时表中插入数据

    INSERT INTO #week_income
    SELECT '星期一',1000
    UNION ALL
    SELECT '星期二',2000
    UNION ALL
    SELECT '星期三',3000
    UNION ALL
    SELECT '星期四',4000
    UNION ALL
    SELECT '星期五',5000
    UNION ALL
    SELECT '星期六',6000
    UNION ALL
    SELECT '星期日',7000

    3一般的查询是这样的 SELECT * FROM #week_income

    但是这样显示的效果是不好的,如果换个sql查询,例如 使用了PIVOT语法,对行列进行转换

    SELECT [星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日]
    FROM #week_income
    PIVOT (
    SUM(income)FOR week IN ([星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日])
    )a

    得到的结果是这样的

    4 然后再把转换后的表格再次的转为原来的形式 ,先准备一个临时表 #cc 

    SELECT * INTO #cc
    FROM #week_income
    PIVOT
    (
    SUM(income)FOR week IN (星期一,星期二,星期三,星期四)
    )a

    临时表的内容格式如下 

    然后通过unpivot sql语法转换 

    SELECT * FROM #cc
    UNPIVOT (income FOR week IN (星期一,星期二,星期三,星期四))b

  • 相关阅读:
    Demo
    Demo
    Demo
    Demo
    Demo
    【csp模拟赛6】树上统计-启发式合并,线段树合并
    【csp模拟赛6】计数--单调栈
    【csp模拟赛6】相遇--LCA
    【poj1734】Sightseeing trip--无向图最小环
    【poj2709】Painter--贪心
  • 原文地址:https://www.cnblogs.com/yachao1120/p/8519548.html
Copyright © 2011-2022 走看看