PIVOT运算符使用(动态行转列)
PIVOT运算符用于在列和行之间对数据进行旋转或透视转换,同时执行聚合运算
官方的语法如下:
PIVOT(
聚合函数(value_column)
FOR pivot_column
IN(<column_list>)
)
我这边有一个保存网站下所有子域名PV的表PV_Test,数据如下

现在要查询每个域名下不同日期的PV
SQL代码如下

DECLARE
--保存最终执行的SQL语句
@strSql nvarchar(1000),
--定义变量保存要转化为列的数据
@Date nvarchar(500)
--赋值 很重要,不赋值执行没结果
SET @Date=''
--赋值 把所有要转化为列的数据保存在字符串中,并且以逗号分隔
SELECT @Date=@Date+CDate FROM (SELECT DISTINCT '['+CONVERT(varchar(10), CDate, 23)+'],' AS CDate FROM PV_Test) AS T1
--打印@Date
PRINT(@Date)
--去掉末尾的一个逗号
SET @Date=SUBSTRING(@Date,1,LEN(@Date)-1)
--使用PIVOT运算符转化
SET @strSql= 'SELECT * FROM (SELECT Domain,CONVERT(varchar(10), CDate, 23) AS RQ,PV FROM dbo.PV_Test) AS a PIVOT(SUM(PV) FOR RQ IN ('+@Date+') ) AS b'
--打印最终执行的SQL
PRINT(@strSql)
--执行sql
EXEC (@strSql)

备注已经写得很清楚了,执行结果如下

可以清楚的看到每个域名下各个日期的PV情况
如果要把上面的NULL值转为0,使用下面的语句:
DECLARE
--保存最终执行的SQL语句
@strSql nvarchar(max),
--定义变量保存要转化为列的数据
@ColumnName nvarchar(max),
@ColumnNameWithIsNull NVARCHAR(max)
--赋值 很重要,不赋值执行没结果
SET @ColumnName=''
SET @ColumnNameWithIsNull=''
--赋值 把所有要转化为列的数据保存在字符串中,并且以逗号分隔
SELECT @ColumnName=@ColumnName + ColumnName FROM
(
SELECT DISTINCT '['+ ColumnName +'],' AS ColumnName,SequenceID
FROM [CustomizedReport].[ColumnList]
) AS T1
ORDER BY T1.SequenceID SELECT @ColumnNameWithIsNull=@ColumnNameWithIsNull + ColumnName FROM
(
SELECT DISTINCT 'ISNULL(['+ ColumnName +'],0) as ['+ ColumnName +'],' AS ColumnName,SequenceID
FROM [CustomizedReport].[ColumnList]
) AS T1
ORDER BY T1.SequenceID
--打印@ColumnName
PRINT(@ColumnName)
PRINT(@ColumnNameWithIsNull)
--去掉末尾的一个逗号
SET @ColumnName=LEFT(@ColumnName,LEN(@ColumnName)-)
SET @ColumnNameWithIsNull=LEFT(@ColumnNameWithIsNull,LEN(@ColumnNameWithIsNull)-)
--使用PIVOT运算符转化
SET @strSql= 'SELECT CompanyID,EmployeeID,'+ @ColumnNameWithIsNull +' FROM (SELECT CompanyID,EmployeeID,ColumnName,Shares FROM [CustomizedReport].[VerticalResult]) AS a PIVOT(max(Shares) FOR ColumnName IN ('+@ColumnName+') ) AS b'
--打印最终执行的SQL
PRINT(@strSql)
--执行sql
EXEC (@strSql)
PIVOT运算符使用(动态行转列)的更多相关文章
- [MSSQL]採用pivot函数实现动态行转列
环境要求:2005+ 在日常需求中常常会有行转列的事情需求处理.假设不是动态的行,那么我们能够採取case when 罗列处理. 在sql 2005曾经处理动态行或列的时候,通常採用拼接字符串的方法处 ...
- 中等难度SQL语句(存储过程,分页,拼接字段、游标,日期类型转换,动态行转列,视图)汇总
一.创建存储过程 if Exists(select name from sysobjects where NAME = 'sp1LoginUser' and type='P')drop procedu ...
- 【转】MySQL存储过程中使用动态行转列
MySQL存储过程中使用动态行转列 最近做项目关于数据报表处理,然而数据库存储格式和报表展现形式不同,需要进行一下行转列的操作,在做上一个项目的时候也看了一下,但是后来换了读取方式,也就没深入研究这个 ...
- MySQL 行转列 -》动态行转列 -》动态行转列带计算
Pivot Table Using MySQL - A Complete Guide | WebDevZoomhttp://webdevzoom.com/pivot-table-using-mysql ...
- mybatis 动态行转列
SELECT user_name , MAX(CASE course WHEN '数学' THEN score END ) 数学, MAX(CASE course WHEN '语文' THEN sco ...
- MySQL存储过程的动态行转列
MySQL存储过程中使用动态行转列 最近做项目关于数据报表处理,然而数据库存储格式和报表展现形式不同,需要进行一下行转列的操作,在做上一个项目的时候也看了一下,但是后来换了读取方式,也就没深入研究这个 ...
- 在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列)
原文:在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
- 在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)
原文:在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉 ...
- 在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名)
原文:在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
- 在论坛中出现的比较难的sql问题:36(动态行转列 解析json格式字符串)
原文:在论坛中出现的比较难的sql问题:36(动态行转列 解析json格式字符串) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
随机推荐
- W3CSchool CSS学习简记
什么是 CSS? CSS 指层叠样式表 (Cascading Style Sheets) 样式定义如何显示 HTML 元素 样式通常存储在样式表中 把样式添加到 HTML 4.0 中,是为了解决内 ...
- ZH奶酪:Linux新建用户+远程登录
7.想在VBUbuntu中新建一个账户,但是用useradd命令发现没有权限,原来Ubuntu默认不是root权限登录,需要按照下边的教程才能新建用户. http://www.linuxidc.com ...
- Socket 之 传值方式
一.传送 DataTable 和 DataSet 1.发送端需序列化数据为二进制序列化格式 public static byte[] GetBinaryFormatDataSet(DataSet ds ...
- 从零开始学JavaScript三(变量)
一.变量 ECMAscript变量是松散型变量,所谓松散型变量,就是变量名称可以保存任何类型的数据,每个变量仅仅是一个用于保存值的占位符. 定义变量时要使用var操作符 如: var message; ...
- ONVIFclient搜索设备获取rtsp地址开发笔记(精华篇)
概要: 眼下ONVIF协议家族设备已占领数字监控行业半壁江山以上.亲,作为开发人员的你还在犹豫是否了解下吗?本文介绍了ONVIFclient从设备搜索,鉴权,能力获取,媒体信息获取 ...
- break的使用方法
private static void test() { for (int i = 0; i < 5; i++) { for (int j = 0; j < 5; j++) { Syst ...
- expdp impdp 错误: ORA-39064: 无法写入日志文件 ORA-29285: 文件写入错误(解决方案)
windows: 运行 -> regedit ->查找 键值 NLS_LANG 将字符集 SIMPLIFIED CHINESE_CHINA.ZHS16GBK 修改为AMERICAN_AME ...
- JDBC 实例--JDBC通过工具类DBUtil连接到数据库,让我们不再恐惧操作数据库
利用JDBC连接到数据库一般需要几个步骤: 1.装载驱动程序. 2.建立连接. 3.发送和执行SQL语句. 4.释放资源 首先建立一个数据库: 脚本如下: create database csdn; ...
- POJ 1159 Palindrome(区间DP/最长公共子序列+滚动数组)
Palindrome Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 56150 Accepted: 19398 Desc ...
- 添加space_key, enter_key, clear_key, delete_key的处理。
final EditText view = (EditText) mInflater.inflate(R.layout.sms_receipient_input, null); view.setOnK ...