当前位置: 代码迷 >> Sql Server >> 求一条SQL语句!解决办法
  详细解决方案

求一条SQL语句!解决办法

热度:68   发布时间:2016-04-27 15:27:36.0
求一条SQL语句!急
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 行)
  相关解决方案