求一条SQL语句!

 我来答
漓江南方
2014-03-21 · 超过36用户采纳过TA的回答
知道小有建树答主
回答量:98
采纳率:0%
帮助的人:54.8万
展开全部

经过测试:

select aa.job 代码,aa.sal 类别1,bb.sal 类别2,cc.sal 类别3,dd.sal 类别4 from
(select a.job,a.sal from (select job,sal,row_number() over(partition by job order by job) pm from emp) a where a.pm =1) aa
left outer join
(select b.job,b.sal from (select job,sal,row_number() over(partition by job order by job) pm from emp) b where b.pm =2) bb
on aa.job=bb.job
left outer join
(select c.job,c.sal from (select job,sal,row_number() over(partition by job order by job) pm from emp) c where c.pm =3) cc
 on bb.job=cc.job
left outer join
(select d.job,d.sal from (select job,sal,row_number() over(partition by job order by job) pm from emp) d where d.pm =4) dd
 on cc.job=dd.job

wjm0506
2014-03-21 · TA获得超过147个赞
知道小有建树答主
回答量:259
采纳率:0%
帮助的人:174万
展开全部
select a.代码,sum(decode(a.类别,'1',a.数量)) 类别1,sum(decode(a.类别,'2',a.数量)) 类别2,sum(decode(a.类别,'3',a.数量)) 类别3,sum(decode(a.类别,'41',a.数量)) 类别4 from T1 a group by a.代码 order by a.代码

PS:我的是oracle,别的没试过 如果是mysql用case一样的效果

mysql & oracle

select a.代码,sum(case a.类别 when '1' then a.数量 end) 类别1,sum(case a.类别 when '2' then a.数量 end) 类别2,sum(case a.类别 when '3' then a.数量 end) 类别3,sum(case a.类别 when '4' then a.数量 end) 类别4 from T1 a group by a.代码 order by a.代码
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友ef2ed3d99
2014-03-21 · 超过71用户采纳过TA的回答
知道小有建树答主
回答量:182
采纳率:0%
帮助的人:133万
展开全部
select 代码
,isNull(类别1,'') as 类别1
,isNull(类别2,'') as 类别2
,isNull(类别3,'') as 类别3
,isNull(类别4,'') as 类别4
from (
select 代码
,类别=(case 类别 when 1 then '类别1' when 2 then '类别2' when 3 then '类别3' when 4 then '类别4' end)
,数量
from T1) T2
pivot(max(数量) for 类别 in([类别1],[类别2],[类别3],[类别4]))a
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式