table1
BN-00000004 .0000 收
BN-00000005 .0000 收
BN-00000003 .0000 收
BN-00000002 .0000 收
BN-00000001 .0000 收
table2
asdfef asdf fqwefqe[15] 15 23466.0000 .0000
sadfas asdf asdfee[12] 12 123123.0000 .0000
ef234 asdf aee23[13] 13 1244.0000 .0000
asdfef asdf dfw334[14] 14 23456.0000 .0000
asdf asdf eqerr[11] 11 1111.0000 .0000
我要的结果是
编码 fqwefqe[15] asdfee[12] aee23[13] dfw334[14] eqerr[11]
BN-00000004 23466.0000
BN-00000005 1244.0000
BN-00000003 123123.0000
BN-00000002 1111.0000
BN-00000001 23456.0000
------解决方案--------------------
确实看不清楚,给个列自己看吧.
- SQL code
普通行列转换假设有张学生成绩表(t)如下Name Subject Result张三 语文 73张三 数学 83张三 物理 93李四 语文 74李四 数学 84李四 物理 94想变成 姓名 语文 数学 物理张三 73 83 93李四 74 84 94create table #t( Name varchar(10) , Subject varchar(10) , Result int)insert into #t(Name , Subject , Result) values('张三','语文','73')insert into #t(Name , Subject , Result) values('张三','数学','83')insert into #t(Name , Subject , Result) values('张三','物理','93')insert into #t(Name , Subject , Result) values('李四','语文','74')insert into #t(Name , Subject , Result) values('李四','数学','83')insert into #t(Name , Subject , Result) values('李四','物理','93')declare @sql varchar(8000)set @sql = 'select Name as ' + '姓名'select @sql = @sql + ' , sum(case Subject when ''' + Subject + ''' then Result end) [' + Subject + ']'from (select distinct Subject from #t) as aset @sql = @sql + ' from #t group by name'exec(@sql) drop table #t--结果姓名 数学 物理 语文 ---------- ----------- ----------- ----------- 李四 83 93 74张三 83 93 73 ----------------------------------------------------如果上述两表互相换一下:即姓名 语文 数学 物理张三 73 83 93李四 74 84 94想变成 Name Subject Result张三 语文 73张三 数学 83张三 物理 93李四 语文 74李四 数学 84李四 物理 94create table #t( 姓名 varchar(10) , 语文 int , 数学 int , 物理 int)insert into #t(姓名 , 语文 , 数学 , 物理) values('张三',73,83,93)insert into #t(姓名 , 语文 , 数学 , 物理) values('李四',74,84,94)select 姓名 as Name,'语文' as Subject,语文 as Result from #t unionselect 姓名 as Name,'数学' as Subject,数学 as Result from #t unionselect 姓名 as Name,'物理' as Subject,物理 as Result from #torder by 姓名 desc drop table #t --结果Name Subject Result ---------- ------- ----------- 张三 数学 83张三 物理 93张三 语文 73李四 数学 84李四 物理 94李四 语文 74(所影响的行数为 6 行)