这样子能不能办到?

ehopejxb 2005-09-23 04:31:21
表:
name xm sj
A a 1.2
A b 2.3
A a 1.1
A b 2.2
A a 1.3
A b 2.4

我想这样子显示出来
name a b
A 1.2 2.3
A 1.1 2.2
A 1.3 2.4

不知道各位大哥有没有办法?
...全文
65 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
wgsasd311 2005-09-23
  • 打赏
  • 举报
回复
create table t1(name char(1),xm char(1),sj decimal(9,2))
insert t1
select 'A','a',1.2 union all
select 'A','b',2.3 union all
select 'A','a',1.1 union all
select 'A','b',2.2 union all
select 'A','a',1.3 union all
select 'A','b',2.4
select * from t1
alter table t1 add sid int identity(1,1)
go
select [name],
a=sum(case xm when 'a' then sj end),
b=sum(case xm when 'b' then sj end)
from t1 group by name,(sid-1)/2
go

drop table t1
/*
name xm sj
---- ---- -----------
A a 1.20
A b 2.30
A a 1.10
A b 2.20
A a 1.30
A b 2.40

(所影响的行数为 6 行)


(所影响的行数为 6 行)

name a b
---- ---------------------------------------- ----
A 1.20 2.30
A 1.10 2.20
A 1.30 2.40

(所影响的行数为 3 行)

警告: 聚合或其它 SET 操作消除了空值。

*/
xueguang 2005-09-23
  • 打赏
  • 举报
回复
declare @sql varchar(8000)
set @sql = 'select name'
select @sql = @sql +',['+ xm+']=sum(case xm when '''+ xm +''' then sj else 0 end)' from 表 group by xm
set @sql = @sql +' from 表 group by name'
exec(@sql)
xueguang 2005-09-23
  • 打赏
  • 举报
回复
declare @sql varchar(8000)
set @sql = 'select name'
select @sql = @sql +',['+ xm+']=sum(case xm when '''+ xm +''' then sj else 0 end)' from 表 group by xm
set @sql = @sql +' from tblA group by name'
exec(@sql)
子陌红尘 2005-09-23
  • 打赏
  • 举报
回复
create table 表(name varchar(10),xm varchar(10),sj numeric(2,1))
insert into 表 select 'A','a',1.2
insert into 表 select 'A','b',2.3
insert into 表 select 'A','a',1.1
insert into 表 select 'A','b',2.2
insert into 表 select 'A','a',1.3
insert into 表 select 'A','b',2.4



select identity(int,0,1) as id,* into #t from 表

select
name,
a = max(case xm when 'a' then sj end),
b = max(case xm when 'b' then sj end)
from
#t
group by
id/2,name


drop table 表,#T
ynxuzhao 2005-09-23
  • 打赏
  • 举报
回复
忘记加sum了, 呵呵
ynxuzhao 2005-09-23
  • 打赏
  • 举报
回复
select
name,
a=(case when xm='a' then sj end),
b=(case when xm='b' then sj end)
from 表
churchatp1 2005-09-23
  • 打赏
  • 举报
回复
假设表名位table1
select name,a=sum(case when xm='a' then sj else 0 end)
b=sum(case when xm='b' then sj else 0 end)
from table1 aa

22,209

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧