上次说到,既然有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 的处理方式的更多相关文章

  1. @DisallowConcurrentExecution 注解的作用 【定时器执行完当前任务才开启下一个线程的方式】

    转: @DisallowConcurrentExecution 注解的作用 2018年10月12日 16:42:40 fly_captain 阅读数:4317   Quartz定时任务默认都是并发执行 ...

  2. PIVOT(透视转换)和UNPIVOT(逆透视转换)

    一.原数据状态 二.手动写透视转换1 三.手动写透视转换2 四.PIVOT(透视转换)和UNPIVOT(逆透视转换)详细使用 使用标准SQL进行透视转换和逆视转换 --行列转换 create tabl ...

  3. sql的行转列(PIVOT)与列转行(UNPIVOT) webapi 跨域问题 Dapper 链式查询 扩展 T4 代码生成 Demo (抽奖程序)

    sql的行转列(PIVOT)与列转行(UNPIVOT)   在做数据统计的时候,行转列,列转行是经常碰到的问题.case when方式太麻烦了,而且可扩展性不强,可以使用 PIVOT,UNPIVOT比 ...

  4. 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/ ...

  5. IIS下的身份验证方式管理

    设置.查看身份验证方式 #导航到某站点下: cd IIS:\Sites\DemoSite\DemoApp #启用站点test01下的Windows身份验证 Set-WebConfigurationPr ...

  6. Linux/centos/redhat下各种压缩解压缩方式详解

    1.zip命令 zip -r myfile.zip ./* 将当前目录下的所有文件和文件夹全部压缩成myfile.zip文件,-r表示递归压缩子目录下所有文件. 2.unzip unzip -o -d ...

  7. AndroidUI组件之ActionBar--基于下拉的导航方式

      在上一篇关于ActionBar的博文中.我们知道了ActionBar是Android3.0的重要更新之中的一个.本篇博文就来写一个开发中经经常使用到的样例.用ActionBar提供基于下拉的导航方 ...

  8. Linux 和 Windows 下实现多进程的方式以及管道操作

    一.多进程 1.windows 多进程 使用 #include<windows.h> 下面的 BOOL CreateProcess( LPCWSTR pszImageName, LPCWS ...

  9. ipv6下jdbc的连接数据库方式

    ipv6下jdbc的连接数据库方式 MySQL: ipv4 Driver URL:           jdbc:mysql://127.0.0.1:3306/database   ipv6 Driv ...

随机推荐

  1. Verilog学习笔记简单功能实现(五)...............序列检测设计

    这里采用夏宇闻教授第十五章的序列检测为例来学习; 从以上的状态转换图可以写出状态机的程序: module seqdet(x,out,clk,rst); input x,clk,rst; output ...

  2. C语言的数据、常量和变量

    一.数据 图片文字等都是数据,在计算机中以0和1存储. (一)分类 数据分为静态数据和动态数据. ①. 静态数据:一些永久性的的数据,一般存储在硬盘中,只要硬盘没坏数据都是存在的.一般以文件的形式存储 ...

  3. Hibernate(一)__简介

    一. hibernate是什么 (一)hibernate 是一个orm框架,orm (object relation mapping) 对象关系映射框架 o object -> 业务层(只对对象 ...

  4. 自己总结的web前端知识体系大全【欢迎补充】

    1. 前言 大约在几个月之前,让我看完了<webkit技术内幕>这本书的时候,突然有了一个想法.想把整个web前端开发所需要的知识都之中在一个视图中,形成一个完整的web前端知识体系,目的 ...

  5. Salvattore:CSS 驱动的 jQuery Masonry 插件

    Salvattore 是一个 jQuery 砌体的替代,使用 CSS 驱动的配置.Salvattore 根据您指定的列数组织你的 HTML 元素.容器中的每一个项目会一个接一个被放置在列内,只需要简单 ...

  6. [deviceone开发]-仿微信应用(一):框架搭建

    一.简介 这个示例是一步一步跟我学DeviceOne开发 - 仿微信应用系列文档对应的文档.详细介绍了ListView,IndexListView,add方法等常用功能,推荐初学者学习. 二.效果图 ...

  7. [deviceone开发]-do_Dialog的基本使用示例

    一.简介 我们平常使用do_Notification的alert或者confirm都是比较简单弹窗. 更为复杂和个性化的弹窗需要用到do_Dialog, 它可以弹出一个自定义的窗口,窗口里的内容是你自 ...

  8. DEV柱状图----傻瓜版

    this.chartControl1.Series.Clear();//清空 //获得数据 sqldb sqldb = new sqldb(); string sql = "select T ...

  9. 高级SQL语句

    改变数据 insert record 插入一行 insert into foods (name, type_id) values ('Cinnamon Bobka', 1); 如果在insert语句中 ...

  10. Facebook开源动画库 POP-POPSpringAnimation运用

    POPSpringAnimation也许是大多数人使用POP的理由 其提供一个类似弹簧一般的动画效果:实例源代码已经上传至gitHub,地址:https://github.com/wujunyang/ ...