例如查询周一至周日全部的收入

在数据库操作中,有个别时候大家相见必要达成“行转列”的须要,比如一下的表为某商厦的28日收入情形表:

WEEK_INCOME(WEEK VARCHAR(10),INCOME DECIMAL)

我们先插入一些模拟数据:

INSERT INTO WEEK_INCOME SELECT '星期一',1000UNION ALLSELECT '星期二',2000UNION ALLSELECT '星期三',3000UNION ALLSELECT '星期四',4000UNION ALLSELECT '星期五',5000UNION ALLSELECT '星期六',6000UNION ALLSELECT '星期日',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 SELANDVEENVISION二〇〇五中提供了进一层方便的法子,那正是"PIVOT"关系运算符。,以下是选用PIVOT实现“行转列”的SQL语句

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

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

(v=sql.105).aspx

只是MSDN上的陈说太过头正统严肃,我看了半天尚未弄领悟什么利用PIVOT,搞不清楚PIVOT里面包车型客车语法的意思。于是又google了成都百货上千材质,甚至因此地点提到的WEEK_INCOME表例子作了考试,最终搞明白了其用法。在英特网有篇博文解释的很好:,基本上本身要写的正是参照该博文,再拉长本人一点民用精通。

要知道PIVOT语法,正是要掌握微软为啥那样设计PIVOT,但我相信是现实性供给催生设计思路,所以算是大家依旧要弄明白哪些是“行转列”:

平常景况下的查询结果是那般:

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

行转列后是这么:

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

也正是说,行转列后,原本的某部列的值变做了列名,在这里地正是原来WEEK列的值“周二”,"星期四"..."周天"边做了列名,而作者辈供给做的另一个干活就是总结这几个列的值

现今重新组合注释来解析一下PIVOT语法(在此从前最佳看看自家下面提到博文:,里面聊起的PIVOT语法的四个步骤挺首要卡塔尔国:

SELECT [星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日]--这里是PIVOT第三步这里可以用“*”表示选择所有列,也可以只选择某些列(也就是某些天)FROM WEEK_INCOME --这里是PIVOT第二步骤(准备原始的查询结果,因为PIVOT是对一个原始的查询结果集进行转换操作,所以先查询一个结果集出来)这里可以是一个select子查询,但为子查询时候要指定别名,否则语法错误PIVOT( SUM(INCOME) for [week] in([星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日])--这里是PIVOT第一步骤,也是核心的地方,进行行转列操作。聚合函数SUM表示你需要怎样处理转换后的列的值,是总和(sum),还是平均(avg)还是min,max等等。例如如果week_income表中有两条数据并且其week都是“星期一”,其中一条的income是1000,另一条income是500,那么在这里使用sum,行转列后“星期一”这个列的值当然是1500了。后面的for [week] in([星期一],[星期二]...)中 for [week]就是说将week列的值分别转换成一个个列,也就是“以值变列”。但是需要转换成列的值有可能有很多,我们只想取其中几个值转换成列,那么怎样取呢?就是在in里面了,比如我此刻只想看工作日的收入,在in里面就只写“星期一”至“星期五”。总的来说,SUM(INCOME) for [week] in([星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日])这句的意思如果直译出来,就是说:将列[week]值为"星期一","星期二","星期三","星期四","星期五","星期六","星期日"分别转换成列,这些列的值取income的总和。)TBL--别名一定要写

以上是自个儿对PIVOT的知情,笔者尽所能表明出来。可是话说回来,个人的接头的法子也不相同,就像是作者起来看了不计其数篇博文,都未曾搞领悟PIVOT用法。结果照旧硬的经过例子和人家的博文再增多考虑才弄懂了,所以假若各位看了本篇之后仍不能够明白,那很健康,协作例子再增添本人观念,慢慢的定能精晓。

总结

如上正是那篇著作的全体内容了,希望本文的从头到尾的经过对大家的就学或然专业富有自然的参照学习价值,多谢我们对台本之家的支撑。

本文由快3平台发布于快3正规平台数据库,转载请注明出处:例如查询周一至周日全部的收入

相关阅读