行变列

wqvbjhc 2010-10-28 05:22:37
OWENER_ID COMMODITY_ID STATUS
飞扬电脑城 E5300 1
飞扬电脑城 E5300 2
飞扬电脑城 E5300 2
飞扬电脑城 E5300 1
飞扬电脑城 E5300 1
飞扬电脑城 E5300 1
statue 只有 1 跟 2

想要得到下面的一个视图,如何写sql语句啊
OWENER_ID COMMODITY_ID STATUS1 STATUS2
飞扬电脑城 E5300 4 2
...全文
25 点赞 收藏 2
写回复
2 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
wqvbjhc 2010-10-28
SQL就是高手云集,回答问题真快。谢谢
回复
SQLCenter 2010-10-28
--> 测试数据:#
if object_id('tempdb.dbo.#') is not null drop table #
create table #(OWENER_ID varchar(10), COMMODITY_ID varchar(8), STATUS int)
insert into #
select '飞扬电脑城', 'E5300', 1 union all
select '飞扬电脑城', 'E5300', 2 union all
select '飞扬电脑城', 'E5300', 2 union all
select '飞扬电脑城', 'E5300', 1 union all
select '飞扬电脑城', 'E5300', 1 union all
select '飞扬电脑城', 'E5300', 1

select OWENER_ID, COMMODITY_ID,
STATUS1 = sum(case STATUS when 1 then 1 else 0 end),
STATUS2 = sum(case STATUS when 2 then 1 else 0 end)
from # group by OWENER_ID, COMMODITY_ID

/*
OWENER_ID COMMODITY_ID STATUS1 STATUS2
---------- ------------ ----------- -----------
飞扬电脑城 E5300 4 2
*/

回复
相关推荐
发帖
疑难问题
创建于2007-09-28

2.1w+

社区成员

MS-SQL Server 疑难问题
申请成为版主
帖子事件
创建了帖子
2010-10-28 05:22
社区公告
暂无公告