行表:

行表
姓名 属性 属性值
JACK 身高 180
JACK 体重 80
JACK 年龄 27
TOM 身高 164
TOM 体重 59
TOM 年龄 20

列表:

列表  
姓名 身高 年龄 体重
JACK 180 27 80
TOM 164 20 59

行转列就是将行表转换为列表,反之为列转行。

--==================================================================
----------------------------行转列----------------------------------
--==================================================================
-------------------------建立测试表
if exists(select * from sysobjects where ID=OBJECT_ID(N'BodyInfo') AND XTYPE='U')
DROP TABLE BodyInfo
Create Table BodyInfo
(
姓名 varchar(20),
属性 VARCHAR(20),
属性值 int
)
------------------------插入测试数据
insert into BodyInfo
select 'JACK','身高',180 union all
select 'JACK','体重',80 union all
select 'JACK','年龄',27 union all
select 'TOM','身高',164 union all
select 'TOM','体重',59 union all
select 'TOM','年龄',20 ----------------------------------------方法一:使用静态SQL
select 姓名,
max(case 属性 when '身高' then 属性值 else 0 end) AS 身高,
max(case 属性 when '体重' then 属性值 else 0 end) As 体重,
max(case 属性 when '年龄' then 属性值 else 0 end) AS 年龄
from BodyInfo group by 姓名 ----------------------------------------方法二:使用动态SQL
DECLARE @sql varchar(1000)
set @sql='select 姓名'
select @sql=@sql+',max(case 属性 when '''+属性+''' then 属性值 else 0 end) AS '+属性+''
from (select distinct 属性 from BodyInfo) a
set @sql=@sql+' from BodyInfo group by 姓名'
--print @sql
exec(@sql) ----------------------------------------方法三:使用isnull
go
/*isnull的语法是:ISNULL ( check_expression , replacement_value )
参数
check_expression 将被检查是否为 NULL的表达式。check_expression 可以是任何类型的。 replacement_value 在 check_expression 为 NULL时将返回的表达式。replacement_value 必须与 check_expresssion 具有相同的类型。 返回类型
返回与 check_expression 相同的类型。
*/
declare @sql varchar(8000) select @sql=isnull(@sql+',','')+'max(case 属性 when '''+属性+''' then 属性值 else 0 end) ['+属性+']' from (select distinct 属性 from BodyInfo) b set @sql='select 姓名,'+@sql+' from BodyInfo group by 姓名'
print @sql
exec(@sql) --------------------------------------------------方法四:使用pivot select * from BodyInfo pivot(max(属性值)for 属性 in(身高,体重,年龄))a --------------------------------------------------方法五:使用stuff扩展pivot多变量赋值 go
declare @sql varchar(8000) set @sql='' --初始化变量@sql select @sql=@sql+','+属性 from BodyInfo group by 属性--变量多值赋值 set @sql=stuff(@sql,1,1,'')--去掉首个',' set @sql='select * from BodyInfo pivot (max(属性值) for 属性 in ('+@sql+'))a' exec(@sql) ------------------------------------------方法六:使用isnull扩展pivot多变量赋值 go declare @sql varchar(8000) select @sql=isnull(@sql+',','')+属性 from BodyInfo group by 属性 set @sql='select * from BodyInfo pivot (max(属性值) for 属性 in ('+@sql+'))a' exec(@sql) --==================================================================
----------------------------列转行----------------------------------
--==================================================================
--建立测试表
if exists(select * from sysobjects where id=OBJECT_ID(N'personInfo') AND XTYPE='U')
DROP TABLE personInfo
create table personInfo
(
姓名 varchar(20),
身高 int,
年龄 int,
体重 int
)
----插入测试数据
INSERT INTO personInfo
SELECT 'JACK',180,27,80 UNION ALL
SELECT 'TOM',164,20,59 -------------------------------------------------方法一:使用CASE...WHEN select * from ( select 姓名,属性='身高',属性值=身高 from personInfo union all select 姓名,属性='体重',属性值=体重 from personInfo union all select 姓名,属性='年龄',属性值=年龄 from personInfo ) t order by 姓名,case 属性 when '身高' then 1 when '体重' then 2 when '年龄' then 3 end ------------------------------------------------调用系统表
--调用系统表。
go
declare @sql varchar(8000) select @sql=isnull(@sql+' union all ','')+' select 姓名, [属性]=' +quotename(Name,'''')+' , [属性值] = '+quotename(Name)+' from personInfo' from syscolumns where Name!='姓名'and ID=object_id('personInfo')--表名personInfo,不包含列名为姓名的其他列 order by colid set @sql=@sql+' order by 姓名'
--print @sql
exec(@sql) -----------------------------------------------使用UNPIVOT
SELECT 姓名 ,
属性 ,
属性值
FROM personInfo UNPIVOT ( 属性值 FOR 属性 IN ( [身高], [体重], [年龄] ) ) t ----------------------------------------------使用isnull扩展UNPIVOT
go
DECLARE @sql NVARCHAR(4000) SELECT @sql = ISNULL(@sql + ',', '') + QUOTENAME(name)
FROM syscolumns
WHERE id = OBJECT_ID('personInfo')
AND name NOT IN ( '姓名' )
ORDER BY colid SET @sql = 'select 姓名,[属性],[属性值] from personInfo unpivot ([属性] for [属性值] in(' + @sql
+ '))b' EXEC(@sql)

SQLserver行转列与列转行的更多相关文章

  1. SQLServer处理行转列和列转行

    掌握SQL Server 行转列和列转行 1.列转行 数据经过计算加工后会直接生成前端图表需要的数据源,但是程序里又需要把该数据经过列转行写入中间表中,下次再查询该数据时直接从中间表查询数据. 1.1 ...

  2. sqlserver 行转列、列转行[转]

    转自:http://www.cnblogs.com/luofuxian/archive/2012/02/23/2364328.html Sql Server 行转列.列转行   创建表:   CREA ...

  3. SqlServer 行转列,列转行 以及PIVOT函数快速实现行转列,UNPIVOT实现列转行

     一   .列转行 创建所需的数据 CREATE TABLE [StudentScores]( [UserName] NVARCHAR(20), --学生姓名 [Subject] NVARCHAR(3 ...

  4. 数据库-SqlServer 行转列,列转行

    两篇行转列,列转行的实例文章: 第1篇:https://www.cnblogs.com/cpcpc/archive/2013/04/08/3009021.html 第2篇:https://mp.wei ...

  5. 做图表统计你需要掌握SQL Server 行转列和列转行

    说在前面 做一个数据统计和分析的项目,每天面对着各种数据,经过存储过程从源表计算汇总后需要写入中间结果表以提高数据使用效率,那么此时就需要用到行转列和列转行. 1.列转行 数据经过计算加工后会直接生成 ...

  6. oracle 行转列、列转行

    最近做数据处理,经常遇到需要行转列.列转行的场景,记录个非常简单实用的oracle  列转行.行转的列方法 1.行转列,基础数据如下 做行转列处理 处理SQL select user_name,max ...

  7. SQL 行转列和列转行

    SQL 行转列和列转行 行列互转,是一个经常遇到的需求.实现的方法,有case when方式和2005之后的内置pivot和unpivot方法来实现. 在读了技术内幕那一节后,虽说这些解决方案早就用过 ...

  8. sql中的行转列和列转行的问题

    sql中的行转列和列转行的问题 这是一个常见的问题,也是一个考的问题 1.行转列的问题  简单实例 CREATE TABLE #T ( MON1 INT, MON2 INT, MON3 INT ) G ...

  9. (转载)重温SQL——行转列,列转行

    原文地址:http://www.cnblogs.com/kerrycode/archive/2010/07/28/1786547.html 行转列,列转行是我们在开发过程中经常碰到的问题.行转列一般通 ...

  10. sql 行转列 PIVOT 列转行 UNPIVOT

    原文:sql 行转列 PIVOT 列转行 UNPIVOT 一: 现有表一(t_table1),想转为表二(t_table2)的格式. 表一: 年 公司 收入 2013 公司1 12 2013 公司2 ...

随机推荐

  1. 使用SourceTree

    SourceTree是个git的GUI软件. 教程将“使用Git”那个小节可视化,更为直观. 第一次启动的时候选择忽略,然后直接进入界面.  填入git地址与注册邮箱即可 例如mindset这本书的g ...

  2. 《算法导论》习题解答 Chapter 22.1-4(去除重边)

    思路:重开一个新图,按着邻接列表的顺序从上到下遍历,每遍历一行链表前,清空visited数组,如果没有访问过这个元素,则加入新图,如果已经访问过了(重边),则不动. 伪代码: 复杂度:O(V+E) f ...

  3. jquery plugins —— datatables 增加行号

    table = $("#Table").DataTable({ "rowCallback": function (row, data, dataIndex) { ...

  4. linux-``反引号

    反引号`` 这个东西的用法,我百度了一下,和$()是一样的.在执行一条命令时,会先将其中的 ``,或者是$() 中的语句当作命令执行一遍,再将结果加入到原命令中重新执行,例如:echo `ls`会先执 ...

  5. React Native学习-控制横竖屏第三方组件:react-native-orientation

    在项目中,有时候可能会想使不同的页面显示的横竖屏也不一样,比如前一段我做的<广播体操>的项目,在首页面,肯定是想使页面为竖屏显示,但是播放页面要为横屏显示,即使用户的手机可以转屏,我们的播 ...

  6. hdu 3966 树链剖分

    思路:树链剖分入门题,我这门入得好苦啊,程序很快写出来了,可是在LCA过程中把update函数里的左右边界位置写反了,一直RE到死. #pragma comment(linker, "/ST ...

  7. Unity3d之按键

    if (Input.GetKeyDown(KeyCode.A)){ Debug.Log("您按下了A键"); } if (Input.GetKeyUp(KeyCode.A)) { ...

  8. 关于在windows环境下配置xampp多站点问题

    前言 由于开发要求,最近开始了php开发,于是就找到了xampp,wamp等集成环境,关于在windows下的xampp和wamp的配置,我过两天在写两篇分别阐述一下,下面就遇到的多站点的配置问题讲一 ...

  9. asp.net获取select值的方法

    如何使用asp.net获取select值?搜索中发现一个不错的例子,在此与大家分享. 代码: <select runat="server" class="xgxxb ...

  10. js点击button按钮跳转到页面代码

    点击按钮怎么跳转到另外一个页面呢?我们在网站制作中可能是需要的,因为有时我们需要做这样的效果,尤其是将按钮做成一个图片,而点击图片要跳转到新的页面时,怎么做到呢? 这样的效果可以:onclick=&q ...