PIVOT运算符用于在列和行之间对数据进行旋转或透视转换,同时执行聚合运算

官方的语法如下:

PIVOT(

聚合函数(value_column)

FOR pivot_column

IN(<column_list>)

)

我这边有一个保存网站下所有子域名PV的表PV_Test,数据如下

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

SQL代码如下

  1. DECLARE
  2. --保存最终执行的SQL语句
  3. @strSql nvarchar(1000),
  4. --定义变量保存要转化为列的数据
  5. @Date nvarchar(500)
  6. --赋值 很重要,不赋值执行没结果
  7. SET @Date=''
  8. --赋值 把所有要转化为列的数据保存在字符串中,并且以逗号分隔
  9. SELECT @Date=@Date+CDate FROM (SELECT DISTINCT '['+CONVERT(varchar(10), CDate, 23)+'],' AS CDate FROM PV_Test) AS T1
  10. --打印@Date
  11. PRINT(@Date)
  12. --去掉末尾的一个逗号
  13. SET @Date=SUBSTRING(@Date,1,LEN(@Date)-1)
  14. --使用PIVOT运算符转化
  15. 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'
  16. --打印最终执行的SQL
  17. PRINT(@strSql)
  18. --执行sql
  19. EXEC (@strSql)

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

可以清楚的看到每个域名下各个日期的PV情况

如果要把上面的NULL值转为0,使用下面的语句:

  1. DECLARE
  2. --保存最终执行的SQL语句
  3. @strSql nvarchar(max),
  4. --定义变量保存要转化为列的数据
  5. @ColumnName nvarchar(max),
  6. @ColumnNameWithIsNull NVARCHAR(max)
  7. --赋值 很重要,不赋值执行没结果
  8. SET @ColumnName=''
  9. SET @ColumnNameWithIsNull=''
  10. --赋值 把所有要转化为列的数据保存在字符串中,并且以逗号分隔
  11. SELECT @ColumnName=@ColumnName + ColumnName FROM
  12. (
  13. SELECT DISTINCT '['+ ColumnName +'],' AS ColumnName,SequenceID
  14. FROM [CustomizedReport].[ColumnList]
  15. ) AS T1
  16. ORDER BY T1.SequenceID
  17.  
  18. SELECT @ColumnNameWithIsNull=@ColumnNameWithIsNull + ColumnName FROM
  19. (
  20. SELECT DISTINCT 'ISNULL(['+ ColumnName +'],0) as ['+ ColumnName +'],' AS ColumnName,SequenceID
  21. FROM [CustomizedReport].[ColumnList]
  22. ) AS T1
  23. ORDER BY T1.SequenceID
  24. --打印@ColumnName
  25. PRINT(@ColumnName)
  26. PRINT(@ColumnNameWithIsNull)
  27. --去掉末尾的一个逗号
  28. SET @ColumnName=LEFT(@ColumnName,LEN(@ColumnName)-)
  29. SET @ColumnNameWithIsNull=LEFT(@ColumnNameWithIsNull,LEN(@ColumnNameWithIsNull)-)
  30. --使用PIVOT运算符转化
  31. 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'
  32. --打印最终执行的SQL
  33. PRINT(@strSql)
  34. --执行sql
  35. EXEC (@strSql)

PIVOT运算符使用(动态行转列)的更多相关文章

  1. [MSSQL]採用pivot函数实现动态行转列

    环境要求:2005+ 在日常需求中常常会有行转列的事情需求处理.假设不是动态的行,那么我们能够採取case when 罗列处理. 在sql 2005曾经处理动态行或列的时候,通常採用拼接字符串的方法处 ...

  2. 中等难度SQL语句(存储过程,分页,拼接字段、游标,日期类型转换,动态行转列,视图)汇总

    一.创建存储过程 if Exists(select name from sysobjects where NAME = 'sp1LoginUser' and type='P')drop procedu ...

  3. 【转】MySQL存储过程中使用动态行转列

    MySQL存储过程中使用动态行转列 最近做项目关于数据报表处理,然而数据库存储格式和报表展现形式不同,需要进行一下行转列的操作,在做上一个项目的时候也看了一下,但是后来换了读取方式,也就没深入研究这个 ...

  4. MySQL 行转列 -》动态行转列 -》动态行转列带计算

    Pivot Table Using MySQL - A Complete Guide | WebDevZoomhttp://webdevzoom.com/pivot-table-using-mysql ...

  5. mybatis 动态行转列

    SELECT user_name , MAX(CASE course WHEN '数学' THEN score END ) 数学, MAX(CASE course WHEN '语文' THEN sco ...

  6. MySQL存储过程的动态行转列

    MySQL存储过程中使用动态行转列 最近做项目关于数据报表处理,然而数据库存储格式和报表展现形式不同,需要进行一下行转列的操作,在做上一个项目的时候也看了一下,但是后来换了读取方式,也就没深入研究这个 ...

  7. 在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列)

    原文:在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  8. 在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)

    原文:在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉 ...

  9. 在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名)

    原文:在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  10. 在论坛中出现的比较难的sql问题:36(动态行转列 解析json格式字符串)

    原文:在论坛中出现的比较难的sql问题:36(动态行转列 解析json格式字符串) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

随机推荐

  1. LoadRunner 测试 Mysql

    准备文件 1. 下载 MySQL LoadRunner libraries. 下载地址:http://files.cnblogs.com/files/xiaoxitest/MySQL_LoadRunn ...

  2. Cocos2d-x Touch事件处理机制

    在Cocos2d-x中提供两种触摸事件处理机制:CCStandardTouchDelegate和CCTargetedTouchDelegate. 一.如何使用 0.默认情况下CCLayer都是没有启动 ...

  3. ios开发之公交卡系统的设计与实现

    // // main.m // Bus-公交 /* 公交一卡通充值系统.有两种功能选择.第一种投入硬币或者纸币 选择购票,另外一种一卡通充值,充值面额是20,50.100 */ #import < ...

  4. 6、javac命令详解

    javac [ options ] [ sourcefiles ] [ @files ] 参数可按任意次序排列. options 命令行选项. sourcefiles 一个或多个要编译的源文件(例如 ...

  5. apacheBench对网站进行压力测试

    apacheBench对网站进行压力测试 分类: 学习 2014-02-19 10:35 4154人阅读 评论(1) 收藏 举报 apacheBench压力测试 Apache Benchmark下载 ...

  6. Drupal的$messages是怎么显示的?

    Drupal的默认主题bartik会在页面顶部显示系统信息,例如警告.状态等.这个过程是如何实现的? 首先,在bartik目录下找到page.tpl.php,这是bartik主题的页面显示模板.其中有 ...

  7. C++开发安卓、windows下搭建Android NDK开发环境

    1. NDK(Native Development Kit) 1.1 NDK简介 Android NDK是一套允许开发人员使用本地代码(如C/C++)进行Android APP功能开发的工具,通过这个 ...

  8. spring cloud单点登录

    概述 基于springcloud的单点登录服务及基于zuul的网关服务(解决了通过zuul转发到认证服务之后session丢失问题) 详细 代码下载:http://www.demodashi.com/ ...

  9. Android SharedPreferences保存和读取对象

    SharedPreferences保存和读取对象 1.首先要序列化对象(以下是序列化实体类的样例,不方便贴出实体类全部的代码) public class LoginResult extends Bas ...

  10. Android API之android.provider.ContactsContract.Contacts

    android.provider.ContactsContract.Contacts 对应contacts数据表.RawContacts的一个聚合(aggregate)代表同一个人.每个人在数据表co ...