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

    SQL SERVER PIVOT与用法解释

    数据库操作中,有些时候我们遇到需要实现“行转列”需求,例如一下的表为某店铺的一周收入情况表:

     WEEK_INCOME(WEEK VARCHAR(10),INCOME DECIMAL) 

    我们先插入一些模拟数据

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

    一般我们最经常使用的查询是查询一周中每天或某几天的收入,例如查询周一至周日全部的收入:

     SELECT WEEK,INCOME FROM WEEK_INCOME 

    得到如下的查询结果集:

    WEEK           INCOME
    星期一           1000
    星期二           2000
    星期三           3000
    星期四           4000
    星期五           5000
    星期六           6000
    星期日           7000

     

    但是在一些情况下(往往是某些报表中),我们希望再一行中显示周一至周日的收入,这时候查询结果集应该是这样的:

    星期一   星期二   星期三   星期四   星期五   星期六   星期日
    1000    2000    3000    4000    5000    6000    7000

    这种情况下,SQL查询语句可以这样写:

     SELECT SUM(CASE WEEK WHEN '星期一' THEN INCOME END) AS [星期一], SUM(CASE WEEK WHEN '星期二' THEN INCOME END) AS [星期二], SUM(CASE WEEK WHEN'星期三' THEN INCOME END) AS [星期三], SUM(CASE WEEK WHEN '星期四' THEN INCOME END) AS [星期四], SUM(CASE WEEK WHEN '星期五' THEN INCOME END) AS [星期五], SUM(CASE WEEK WHEN '星期六' THEN INCOME END) AS [星期六], SUM(CASE WEEK WHEN '星期日' THEN INCOME END) AS [星期日] FROM WEEK_INCOME 

    但是,在SQL SERVER 2005中提供了更为简便的方法,这就是"PIVOT"关系运算符。(相反的“列转行”是UNPIVOT),一下是使用PIVOT实现“行转列”

     SELECT [星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日] FROM WEEK_INCOME PIVOT ( SUM(INCOME) for [week] in([星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日]) )TBL

    请参考MSDN中关于PIVOT的用法:

    http://technet.microsoft.com/zh-cn/library/ms177410(v=sql.105).aspx

    但是MSDN上的描述太过于规范严肃,我看了半天还没弄清楚怎样使用PIVOT,搞不清楚PIVOT里面的语法的含义。于是又google了很多资料,已经通过上面提高的WEEK_INCOME表例子作了试验,最终稿清楚了其用法。在网上有篇博文解释的很好:T-SQL PIVOT姙法剖析

    怀仁怀朴,唯真唯实。
  • 相关阅读:
    汉语-词语:关怀
    心理学-交流:我真的关心ta,却不知道如何表达 | 如何科学地表达关心?
    汉语-词语:关心
    汉语-词语:安慰
    医疗时鲜资讯:医疗行业未来的变革(续前篇)
    字典转模型的过程中,空值和id特殊字符的处理
    最简单的基于FFmpeg的移动端样例附件:Android 自带播放器
    创建存储过程向表中循环加入数据
    分布式事务 原理及使用范例一则
    hdu 1166
  • 原文地址:https://www.cnblogs.com/hushzhang/p/5274777.html
Copyright © 2011-2022 走看看