一、使用PIVOT实现数据表的列转行

建表语句:

 DROP TABLE STUDENT;
 CREATE TABLE STUDENT (
 学生编号  BYTE) NULL ,
 姓名  BYTE) NULL ,
 性别  BYTE) NULL ,
 所属班级  BYTE) NULL
 )
 ;

 -- ----------------------------
 -- Records of STUDENT
 -- ----------------------------
 ', '李妹妹', '女', '初一 1班');
 ', '泰强', '男', '初一 1班');
 ', '泰映', '男', '初一 1班');
 ', '何谢', '男', '初一 1班');
 ', '李春', '男', '初二 1班');
 ', '吴歌', '男', '初二 1班');
 ', '林纯', '男', '初二 1班');
 ', '徐叶', '女', '初二 1班');
 ', '龙门', '男', '初三 1班');
 ', '小红', '女', '初三 1班');
 ', '小李', '男', '初三 1班');
 ', '小黄', '女', '初三 2班');
 ', '旺财', '男', '初三 2班');
 ', '强强', '男', '初二 1班');

语法:

     SELECT  

     <未透视的列>,  

     [第一个透视列] AS <列别名>,  

     [第二个透视列] AS <列别名>,  

     ...  

     [最后一个透视列] AS <列别名> 

     FROM (  

     <SELECT查询> 

     ) AS <源表> 

     PIVOT (  

     <聚合函数>(<列>)  

     FOR [<需要转换为行的列>] IN (  

     [第一个透视列], [第二个透视列],  

     ...  

     [最后一个透视列]  

     )  

     ) AS <数据透视表> 

     <可选的ORDER BY子句>; 

示例如语句:

 SELECT
     '班级总人数:' AS 总人数,
     初一1班,
     初一2班,
     初二1班,
     初三1班,
     初三2班
 FROM
     (
         SELECT
             所属班级,学生编号
         FROM
             student
     ) PIVOT (
         COUNT (学生编号) FOR 所属班级 IN (
             '初一 1班' AS 初一1班,
             '初一 2班' as 初一2班,
             '初二 1班' as 初二1班,
             '初三 1班' as 初三1班,
             '初三 2班' as 初三2班
         )
     );

二、使用UNPIVOT 实现的功能其实与PIVOT恰恰相反
建表语句:

 ), Q1 int, Q2 int, Q3 int, Q4 int);
 ,,,,);
 ,,,,);
 ,,,,);
 ,,,,);
 select * from Fruit

语法同PIVOT但是UNPIVOT的子句没有聚合函数
语法:

 SELECT  

 <未逆透视的列>,  

 [合并后的列] AS <列别名>,  

 [行值的列名] AS <列别名>

 FROM (  

 <SELECT查询>

 ) AS <源表>

 UNPIVOT (  

 <行值的列名>

 FOR <将原来多个列合并到单个列的列名> IN (  

 [第一个合并列], [第二个合并列],  

 ...  

 [最后一个合并列]  

 )  

 ) AS <数据逆透视表>

 <可选的ORDER BY子句>; 

示例语句:

 select id , name, jidu, xiaoshou from Fruit unpivot (xiaoshou for jidu in (q1, q2, q3, q4) )

PIVOT和UNPIVOT使用详解的更多相关文章

  1. SQL Server 行列相互转换命令:PIVOT和UNPIVOT使用详解

    一.使用PIVOT和UNPIVOT命令的SQL Server版本要求 1.数据库的最低版本要求为SQL Server 2005 或更高. 2.必须将数据库的兼容级别设置为90 或更高. 3.查看我的数 ...

  2. T-SQL行列相互转换命令:PIVOT和UNPIVOT使用详解

    最近在维护一个ERP 做二次开发 ,在查找数据源的时候看到前辈写的SQL ,自己能力有限 ,就在网上找找有关这几个关键字的使用方法.做出随笔以做学习之用 T-SQL语句中,PIVOT命令可以实现数据表 ...

  3. SQL Server数据库PIVOT函数的使用详解(一)

    http://database.51cto.com/art/201108/285250.htm SQL Server数据库中,PIVOT在帮助中这样描述滴:可以使用 PIVOT 和UNPIVOT 关系 ...

  4. SQL Server数据库PIVOT函数的使用详解(二)

    动态的行转列 原理就是 把需要转成列的行拼出来 DECLARE @fieldName VARCHAR(); SET @fieldName=''; SELECT @fieldName = @fieldN ...

  5. SQL(横表和纵表)行列转换,PIVOT与UNPIVOT的区别和使用方法举例,合并列的例子

    使用过SQL Server 2000的人都知道,要想实现行列转换,必须综合利用聚合函数和动态SQL,具体实现起来需要一定的技巧,而在SQL Server 2005中,使用新引进的关键字PIVOT/UN ...

  6. 微软BI SSIS 2012 ETL 控件与案例精讲课程学习方式与面试准备详解

    开篇介绍 微软BI SSIS 2012 ETL 控件与案例精讲 (http://www.hellobi.com/course/21) 课程从2014年9月开始准备,到2014年12月在 天善BI学院  ...

  7. Redis数据结构详解之List(二)

    序言 思来想去感觉redis中的list没什么好写的,如果单写几个命令的操作过于乏味,所以本篇最后我会根据redis中list数据类型的特殊属性,同时对比成熟的消息队列产品rabbitmq,使用red ...

  8. Solr系列五:solr搜索详解(solr搜索流程介绍、查询语法及解析器详解)

    一.solr搜索流程介绍 1. 前面我们已经学习过Lucene搜索的流程,让我们再来回顾一下 流程说明: 首先获取用户输入的查询串,使用查询解析器QueryParser解析查询串生成查询对象Query ...

  9. JS-排序详解:冒泡排序、选择排序和快速排序

    JS-排序详解-冒泡排序 说明 时间复杂度指的是一个算法执行所耗费的时间 空间复杂度指运行完一个程序所需内存的大小 稳定指,如果a=b,a在b的前面,排序后a仍然在b的前面 不稳定指,如果a=b,a在 ...

随机推荐

  1. MySQL报错: Character set ‘utf8mb4‘ is not a compiled character set and is not specified in the ‘/usr/share/mysql/charsets/Index.xml‘ file

    由于日常程序使用了字符集utf8mb4,为了避免每次更新时,set names utf8mb4,就把配置文件改了,如下: [root@~]# vim /etc/my.cnf #my.cnf [clie ...

  2. Selenium+PhantomJS使用时报错原因及解决方案

    问题 今天在使用selenium+PhantomJS动态抓取网页时,出现如下报错信息: UserWarning: Selenium support for PhantomJS has been dep ...

  3. Lua中assert( )函数的使用

    当Lua遇到不期望的情况时就会抛出错误,比如:两个非数字进行相加:调用一个非函数的变量:访问表中不存在的值等.你也可以通过调用error函数显示的抛出错误,error的参数是要抛出的错误信息. ass ...

  4. Spring Boot 导出Excel表格

    Spring Boot 导出Excel表格 添加支持 <!--添加导入/出表格依赖--> <dependency> <groupId>org.apache.poi& ...

  5. Java装饰者模式

    定义:在不改变原有对象的基础上,将功能附加到对象自上 提供了比继承更有弹性的替代方案(扩展原有对象功能) 类型:结构型 扩展一个类的功能或给一个类添加附加职责 动态的给一个对象添加功能,这些功能可以再 ...

  6. C# 把ABCD转换成数字

    每倒题得选项可能是多选或者单选. public static string LetterTransformationNum(string answer, int type) { string num ...

  7. DDD工作流持久化(十六)

    找到对应的sql文件执行sql语句 产生如下的表: 添加引用: 添加命名空间: using System.Activities.DurableInstancing; using System.Runt ...

  8. Caused by: java.net.ConnectException: Connection refused/Caused by: java.lang.RuntimeException: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

    1.使用sqoop技术将mysql的数据导入到Hive出现的错误如下所示: 第一次使用命令如下所示: [hadoop@slaver1 sqoop--cdh5.3.6]$ bin/sqoop impor ...

  9. 【LGR-052】洛谷9月月赛II(加赛)

    题解: 没打... ab题满世界都过了应该没什么意思 c题是个比较有意思的思维题(先看了题解才会的...) 我们考虑这么一件事情 没钥匙的人出门后 门一定是开着的 他进来的时候,门一定是开着的 其他时 ...

  10. RequireJS跨域加载html模版后被转成JS问题分析及解决

    问题描述 RequireJS跨域加载HTML模版失败,例如: 在a.com域名下请求CDN域名下的模版,text.js插件会把html文件转成html.js文件去加载,由于并没有生成html.js文件 ...