说完Pivot 今天说下Unpivot 的处理方式
上次说到,既然有Pivot 的行转列,那么肯定也有Unpivot 的列转行 。其实unpivot 处理的情况也是差不多,也是分3步走。
首先也是先演示一下unpivot 的用法
CREATE TABLE #Emp (Name NVARCHAR(50),Mon TIME,Tue TIME,Wed TIME,Thu TIME) INSERT INTO #Emp
( Name, Mon, Tue, Wed, Thu )
VALUES ( N'Ken', '8:30', '8:45','9:05','8:55' ),
( N'Joan', '8:25', '8:35', NULL,'9:00' ),
( N'Jack', '8:15', '9:03','9:05','8:38' ),
( N'Bob', '9:30', '8:53','9:01','8:56' ) SELECT * FROM #Emp Name Mon Tue Wed Thu
-------------------------------------------------- ---------------- ---------------- ---------------- ----------------
Ken 08:30:00.0000000 08:45:00.0000000 09:05:00.0000000 08:55:00.0000000
Joan 08:25:00.0000000 08:35:00.0000000 NULL 09:00:00.0000000
Jack 08:15:00.0000000 09:03:00.0000000 09:05:00.0000000 08:38:00.0000000
Bob 09:30:00.0000000 08:53:00.0000000 09:01:00.0000000 08:56:00.0000000
SELECT *
FROM #Emp UNPIVOT( [LoginTime] FOR [WeekDay] IN (Mon,Tue,Wed,Thu)) a Name LoginTime WeekDay
-------------------------------------------------- ---------------- --------------------------------------------------------------------------------------------------------------------------------
Ken 08:30:00.0000000 Mon
Ken 08:45:00.0000000 Tue
Ken 09:05:00.0000000 Wed
Ken 08:55:00.0000000 Thu
Joan 08:25:00.0000000 Mon
Joan 08:35:00.0000000 Tue
Joan 09:00:00.0000000 Thu
Jack 08:15:00.0000000 Mon
Jack 09:03:00.0000000 Tue
Jack 09:05:00.0000000 Wed
Jack 08:38:00.0000000 Thu
Bob 09:30:00.0000000 Mon
Bob 08:53:00.0000000 Tue
Bob 09:01:00.0000000 Wed
Bob 08:56:00.0000000 Thu
解释一下,
UNPIVOT( [LoginTime] FOR [WeekDay] IN (Mon,Tue,Wed,Thu)) 里面 。 WeekDay 是 根据 (Mon,Tue,Wed,Thu) 这4个列聚合起来的新列的名称,而 LoginTime 呢,就是存放 (Mon,Tue,Wed,Thu) 这几个列下面的值的新列名称。用起来还是挺方便的。
然后下面我要讲一下unpivot 的3步新路里程
1、赋值元素。首先是会按照 (Mon,Tue,Wed,Thu ) 4个列进行一个行赋值。生成第一步的虚拟表。就像下面一样
SELECT *
FROM #Emp a
FULL JOIN (SELECT 'Mon' AS [WeekDay]
UNION ALL
SELECT 'Tue' AS [WeekDay]
UNION ALL
SELECT 'Wed' AS [WeekDay]
UNION ALL
SELECT 'Thu' AS [WeekDay])b ON 1 = 1 得出中间表
Name Mon Tue Wed Thu WeekDay
-------------------------------------------------- ---------------- ---------------- ---------------- ---------------- -------
Bob 09:30:00.0000000 08:53:00.0000000 09:01:00.0000000 08:56:00.0000000 Mon
Bob 09:30:00.0000000 08:53:00.0000000 09:01:00.0000000 08:56:00.0000000 Tue
Bob 09:30:00.0000000 08:53:00.0000000 09:01:00.0000000 08:56:00.0000000 Wed
Bob 09:30:00.0000000 08:53:00.0000000 09:01:00.0000000 08:56:00.0000000 Thu
Jack 08:15:00.0000000 09:03:00.0000000 09:05:00.0000000 08:38:00.0000000 Thu
Jack 08:15:00.0000000 09:03:00.0000000 09:05:00.0000000 08:38:00.0000000 Wed
Jack 08:15:00.0000000 09:03:00.0000000 09:05:00.0000000 08:38:00.0000000 Tue
Jack 08:15:00.0000000 09:03:00.0000000 09:05:00.0000000 08:38:00.0000000 Mon
Joan 08:25:00.0000000 08:35:00.0000000 NULL 09:00:00.0000000 Tue
Joan 08:25:00.0000000 08:35:00.0000000 NULL 09:00:00.0000000 Mon
Joan 08:25:00.0000000 08:35:00.0000000 NULL 09:00:00.0000000 Wed
Joan 08:25:00.0000000 08:35:00.0000000 NULL 09:00:00.0000000 Thu
Ken 08:30:00.0000000 08:45:00.0000000 09:05:00.0000000 08:55:00.0000000 Thu
Ken 08:30:00.0000000 08:45:00.0000000 09:05:00.0000000 08:55:00.0000000 Mon
Ken 08:30:00.0000000 08:45:00.0000000 09:05:00.0000000 08:55:00.0000000 Tue
Ken 08:30:00.0000000 08:45:00.0000000 09:05:00.0000000 08:55:00.0000000 Wed
2 提取有效元素。结果类似下面语句生成的结果
;WITH CTE AS(
SELECT *
FROM #Emp a
FULL JOIN (SELECT 'Mon' AS [WeekDay]
UNION ALL
SELECT 'Tue' AS [WeekDay]
UNION ALL
SELECT 'Wed' AS [WeekDay]
UNION ALL
SELECT 'Thu' AS [WeekDay])b ON 1 = 1)
SELECT Name,[WeekDay],
CASE [WeekDay] WHEN 'Mon' THEN Mon
WHEN 'Tue' THEN Tue
WHEN 'Wed' THEN Wed
WHEN 'Thu' THEN Thu ELSE NULL END AS LoginTime
FROM CTE Name WeekDay LoginTime
-------------------------------------------------- ------- ----------------
Ken Mon 08:30:00.0000000
Joan Mon 08:25:00.0000000
Jack Mon 08:15:00.0000000
Bob Mon 09:30:00.0000000
Ken Tue 08:45:00.0000000
Joan Tue 08:35:00.0000000
Jack Tue 09:03:00.0000000
Bob Tue 08:53:00.0000000
Ken Wed 09:05:00.0000000
Joan Wed NULL
Jack Wed 09:05:00.0000000
Bob Wed 09:01:00.0000000
Ken Thu 08:55:00.0000000
Joan Thu 09:00:00.0000000
Jack Thu 08:38:00.0000000
Bob Thu 08:56:00.0000000
3 将Null值元素去除。这个好理解了,中间有Null值的行去除
;WITH CTE AS(
SELECT *
FROM #Emp a
FULL JOIN (SELECT 'Mon' AS [WeekDay]
UNION ALL
SELECT 'Tue' AS [WeekDay]
UNION ALL
SELECT 'Wed' AS [WeekDay]
UNION ALL
SELECT 'Thu' AS [WeekDay])b ON 1 = 1),
CTE2 AS (SELECT Name,[WeekDay],
CASE [WeekDay] WHEN 'Mon' THEN Mon
WHEN 'Tue' THEN Tue
WHEN 'Wed' THEN Wed
WHEN 'Thu' THEN Thu ELSE NULL END AS LoginTime
FROM CTE )
SELECT *
FROM CTE2
WHERE CTE2.LoginTime IS NOT NULL Name WeekDay LoginTime
-------------------------------------------------- ------- ----------------
Ken Mon 08:30:00.0000000
Joan Mon 08:25:00.0000000
Jack Mon 08:15:00.0000000
Bob Mon 09:30:00.0000000
Ken Tue 08:45:00.0000000
Joan Tue 08:35:00.0000000
Jack Tue 09:03:00.0000000
Bob Tue 08:53:00.0000000
Ken Wed 09:05:00.0000000
Jack Wed 09:05:00.0000000
Bob Wed 09:01:00.0000000
Ken Thu 08:55:00.0000000
Joan Thu 09:00:00.0000000
Jack Thu 08:38:00.0000000
Bob Thu 08:56:00.0000000
好!然后结果有没有和直接Unpivot 一样呢~揍是一样啦~当然罗~中间语句可能不是我演示的那样,我主要是演示中间的虚拟表~
好!周四了~再坚持一天~就又可以星期六上班班啦!
说完Pivot 今天说下Unpivot 的处理方式的更多相关文章
- @DisallowConcurrentExecution 注解的作用 【定时器执行完当前任务才开启下一个线程的方式】
转: @DisallowConcurrentExecution 注解的作用 2018年10月12日 16:42:40 fly_captain 阅读数:4317 Quartz定时任务默认都是并发执行 ...
- PIVOT(透视转换)和UNPIVOT(逆透视转换)
一.原数据状态 二.手动写透视转换1 三.手动写透视转换2 四.PIVOT(透视转换)和UNPIVOT(逆透视转换)详细使用 使用标准SQL进行透视转换和逆视转换 --行列转换 create tabl ...
- sql的行转列(PIVOT)与列转行(UNPIVOT) webapi 跨域问题 Dapper 链式查询 扩展 T4 代码生成 Demo (抽奖程序)
sql的行转列(PIVOT)与列转行(UNPIVOT) 在做数据统计的时候,行转列,列转行是经常碰到的问题.case when方式太麻烦了,而且可扩展性不强,可以使用 PIVOT,UNPIVOT比 ...
- linux下tomcat配置APR方式HTTPS
一.安装APR 创建/usr/local/apr tar zxvf apr-1.4.5.tar.gz cd apr-1.4.5 ./configure --prefix=/usr/local/apr/ ...
- IIS下的身份验证方式管理
设置.查看身份验证方式 #导航到某站点下: cd IIS:\Sites\DemoSite\DemoApp #启用站点test01下的Windows身份验证 Set-WebConfigurationPr ...
- Linux/centos/redhat下各种压缩解压缩方式详解
1.zip命令 zip -r myfile.zip ./* 将当前目录下的所有文件和文件夹全部压缩成myfile.zip文件,-r表示递归压缩子目录下所有文件. 2.unzip unzip -o -d ...
- AndroidUI组件之ActionBar--基于下拉的导航方式
在上一篇关于ActionBar的博文中.我们知道了ActionBar是Android3.0的重要更新之中的一个.本篇博文就来写一个开发中经经常使用到的样例.用ActionBar提供基于下拉的导航方 ...
- Linux 和 Windows 下实现多进程的方式以及管道操作
一.多进程 1.windows 多进程 使用 #include<windows.h> 下面的 BOOL CreateProcess( LPCWSTR pszImageName, LPCWS ...
- ipv6下jdbc的连接数据库方式
ipv6下jdbc的连接数据库方式 MySQL: ipv4 Driver URL: jdbc:mysql://127.0.0.1:3306/database ipv6 Driv ...
随机推荐
- 纯灌水Linus主义
卖桃君重新整理了Linus的相关故事,在此摘选对自己有触动的内容. 关于生命的意义,李纳斯的解释是,有三件事具有生命的意义.它们是你生活当中所有事情的动机.第一是生存,第二是社会秩序,第三是娱乐.生活 ...
- 项目总结笔记系列 Maven Session1
主题:Maven 参考地址: 1.http://www.yiibai.com/maven/ 2.http://www.icoolxue.com/ 目录 1.环境搭建 2.pom.xml文件解析 3.m ...
- Java面试题总结系列 Servlet
Servlet技术主要是为了使用Web上的HTTP协议而设计的.servlet是在WEB服务器上运行的程序.Java Servlet可以用于处理客户请求或生成动态Web网页.先一个实例.然后解释. 先 ...
- C语言关键字、标识符和注释
一.关键字 C语言提供的有特殊含义的符号,共32个. 在Xcode中关键字全部高亮显示,关键字全部都为小写.如return.int等. 二.标识符 定义:标识符是程序员在程序中自定义的一些符号和名称. ...
- PHP内核探索之变量(2)-理解引用
本文主要内容: 引论 符号表与zval 引用原理 回到最初的问题 一.引论 很久之前写了一篇关于引用的文章,当时写的寥寥草草,很多原理都没有说清楚.最近在翻阅Derick Rethans(home: ...
- 微信公众平台关于fakeid和openid的解析
今天在开发项目的时候遇到了个问题: 搞不清楚微信官方接口的fromusername(openid)和公众平台内每个粉丝所拥有的fakeid,于是在测试号中开始了对以上两项的研究,结果如下: 1.对 ...
- 实体类在Windows程序中的高级应用--------------------》》心境是一种境界。
一.事务 我们在大家学到这,或多或少对事务都有一些理解了.今天的我也对事务有了更深一层的理解对我来说,我想与大家一起分享一下. 解析: 1.ADO.NET提供了事务处理功能 2.C#中开启事务 3.在 ...
- 已解决:Ubuntu php gettext 无效
使用gettext做多文字国际化,按PHP官方文档,在CentOS上OK,在Ubuntu上不行,调试了快1天,试了网上提供的无数方法,终于有一个OK了…… 看到此文的同学别再被坑了…… 感谢:http ...
- Java虚拟机JVM学习06 自定义类加载器 父委托机制和命名空间的再讨论
Java虚拟机JVM学习06 自定义类加载器 父委托机制和命名空间的再讨论 创建用户自定义的类加载器 要创建用户自定义的类加载器,只需要扩展java.lang.ClassLoader类,然后覆盖它的f ...
- Android压力测试工具——Monkey
Android压力测试工具——Monkey Monkey是运行在模拟器上和真机设备上的一段程序,它会产生用户事件的一系列伪随机流,比如点击.触摸.手势,还有很多系统级别的事件.Monkey通常是用来做 ...