Ⅰ sql语句 列转行
-- ========================= PIVOT 行列转置 ===========================
-- 1、【行列转置PIVOT】
declare @Score table(StuNo varchar(10), StuName varchar(50), CourseName varchar(50), Score int)
insert into @Score
select '1', 'Tom', 'Math', 80 union all
select '1', 'Tom', 'English', 82 union all
select '1', 'Tom', 'Geography', 84 union all
select '2', 'Jone', 'Math', 79 union all
select '2', 'Jone', 'English', 88 union all
select '2', 'Jone', 'Geography',86
select * from @Score
SELECT StuNo, StuName, Math, English, [Geography]
FROM @Score PIVOT (MAX(Score) FOR CourseName in (Math, English, [Geography]) ) AS ScoreList
ORDER BY StuNo
-- 2、【列行转置UNPIVOT】
declare @ScoreList table(StuNo varchar(10), StuName varchar(50), Math int, English int, [Geography] int)
insert into @ScoreList
select '1', 'Tom', 80, 82, 84 union all
select '2', 'Jone', 79, 88, 86
select * from @ScoreList
SELECT StuNo, StuName, CourseName, Score
FROM @ScoreList UNPIVOT (Score FOR CourseName in (Math, English, [Geography]) ) AS ScorePvtTable
ORDER BY StuNo
Ⅱ sqlserver 怎么列转行
PIVOT 用于将列值旋转为列名(即行转列),在 SQL Server 2000可以用聚合函数配合CASE语句实现
PIVOT 的一般语法是:PIVOT(聚合函数(列) FOR 列 in (…) )AS P
注意:PIVOT、UNPIVOT是SQL Server 2005 的语法,使用需修改数据库兼容级别(在数据库属性->选项->兼容级别改为 90 )
SQL2008 中可以直接使用
完整语法:
table_source
PIVOT(
聚合函数(value_column)
FOR pivot_column
IN(<column_list>)
)
View Code
UNPIVOT 用于将列明转为列值(即列转行),在SQL Server 2000可以用UNION来实现
完整语法:
table_source
UNPIVOT(
value_column
FOR pivot_column
IN(<column_list>)
)
Ⅲ sql 列转行
先建一张转换后的表
create table changed
(
id number,
key varchar2(10),
val varchar2(10)
)
然后执行下面的插入语句
insert all
into changed(id,key,val) values(id,'a',a)
into changed(id,key,val) values(id,'b',b)
into changed(id,key,val) values(id,'c',c)
into changed(id,key,val) values(id,'d',d)
into changed(id,key,val) values(id,'e',e)
select id,a,b,c,d,e from change;
如果需要继续添加,就模仿上面的格式写好了,最后别忘记commit;
Ⅳ sql2008列转行语句
http://blog.csdn.net/greystar/article/details/5660645
看看上面三种方法是不是你需要的。
Ⅳ SQL 语句列转行
TB_NAME_A Count(TC_TA_ID=TA_ID && TC_TB_ID=TB_ID_A)
TB_NAME_B Count(TC_TA_ID=TA_ID && TC_TB_ID=TB_ID_B)
TC_TB_ID=TB_ID_A,TC_TB_ID=TB_ID_B 这个TB_ID_A,TB_ID_B 代表什么?
Ⅵ sql语句列转行的问题
sqlserver2005及以上版本
CREATETABLEtest(idINT,[USER_ID]VARCHAR(10),door_idVARCHAR(50))
INSERTINTOdbo.test
(id,USER_ID,door_id)
SELECT1,'U100174','0000000015;0000000018;;'
UNIONALL
SELECT2,'U120225','0000000023;'SELECTA.ID,USER_ID,B.door_id
FROM(
SELECTid,USER_ID,door_id=CONVERT(xml,'<root><v>'+REPLACE(door_id,';','</v><v>')+'</v></root>')FROMtest
)A
OUTERAPPLY(
SELECTdoor_id=N.v.value('.','varchar(100)')FROMA.door_id.nodes('/root/v')N(v)
)B
WHEREISNULL(b.door_id,'')<>''
结果:
1 U100174 0000000015
1 U100174 0000000018
2 U120225 0000000023
Ⅶ SQL:列转行,如何实现,最好使用存储过程
比如:
表: Table
字段及数据:
FNO Item
1 a
2 b
3 c
代码如下:
Creat tabel #temp(FNO int)
Declare @a int ,@b int,@c Varchar
Set @a=1
Select @b=Count(*) From Table
While @a<=@b
Select @c=item From Table Where FNO=@a
Exec ('ALTER TABLE #temp ADD' + @C + 'CHAR(50)')
Set @a=@a+1
End
Select * From #Temp
直接在这里写的,没有测试过语法,但思路应该是没问题的。
Ⅷ sql语句列转行
我整理的行转列的问题:
--创建tb表
createtabletb(姓名varchar(10),课程varchar(10),分数int)
insertintotbvalues('张三','语文',74)
insertintotbvalues('张三','数学',83)
insertintotbvalues('张三','物理',93)
insertintotbvalues('李四','语文',74)
insertintotbvalues('李四','数学',84)
insertintotbvalues('李四','物理',94)
go
select*Fromtb
--SQLSERVER2000静态行转列
select姓名as姓名,
max(case课程when'语文'then分数elsenullend)语文,
max(case课程when'数学'then分数elsenullend)数学,
max(case课程when'物理'then分数elsenullend)物理
fromtb
groupby姓名
--SQLSERVER2000动态SQL,指课程不止语文、数学、物理这三门课程。(以下同)
declare@sqlvarchar(8000)
set@sql='select姓名'
select@sql=@sql+',max(case课程when'''+课程+'''then分数else0end)['+课程+']'
from(selectdistinct课程fromtb)asa
set@sql=@sql+'fromtbgroupby姓名'
exec(@sql)
--SQLSERVER2005静态SQL。
select*from(select*fromtb)apivot(max(分数)for课程in(语文,数学,物理))b
--SQLSERVER2005动态SQL。
declare@sqlvarchar(8000)
select@sql=isnull(@sql+'],[','')+课程fromtbgroupby课程
set@sql='['+@sql+']'
exec('select*from(select*fromtb)apivot(max(分数)for课程in('+@sql+'))b')
希望对你的学习有帮助。
Ⅸ oracle的sql语句列转行
不同人的uuid是不一样的吗?
select
(selectzfromtabnameaawherezmc='姓名'andaa.uuid=a.uuid)姓名,
(selectzfromtabnameaawherezmc='年龄'andaa.uuid=a.uuid)年龄,
(selectzfromtabnameaawherezmc='英文名称'andaa.uuid=a.uuid)英文名称,
(selectzfromtabnameaawherezmc='性别'andaa.uuid=a.uuid)性别,
(selectzfromtabnameaawherezmc='入职日期'andaa.uuid=a.uuid)入职日期,
(selectzfromtabnameaawherezmc='个人信息'andaa.uuid=a.uuid)个人信息
from(selectdistinctuuidfromtabname)a
Ⅹ sql列转行,如何把表转化为这个结果一共一行 一列.如何实现.
通用的办法是用动态sql解决:
declare@sqlvarchar(2000);
set@sql='select''';
select@sql=@sql+列名+','from表名;
select@sql=left(@sql,len(@sql)-1)+''''
exec(@sql);
此外,SQL Server2005以上版本可以用XML Path解决。
SELECT列名+','FROM表名FORXMLPATH('')
这样将直接得到'a,b,c,d,d,e,',需要进一步处理去掉最后的逗号