4个回答
展开全部
select cname,
sum(case when year(senddate)=2005 then totalpay else 0 end) as 2005,
sum(case when year(senddate)=2006 then totalpay else 0 end) as 2006
from pay group by cname
如果你senddate不是datetime类型的话year(senddate)=2005就要改成
left(senddate,4)='2005'
sum(case when year(senddate)=2005 then totalpay else 0 end) as 2005,
sum(case when year(senddate)=2006 then totalpay else 0 end) as 2006
from pay group by cname
如果你senddate不是datetime类型的话year(senddate)=2005就要改成
left(senddate,4)='2005'
七鑫易维信息技术
2024-09-02 广告
2024-09-02 广告
Play Video 七鑫易维是致力于机器视觉和人工智能领域的高新科技企业,迄今已专注眼球追踪技术的研发、创新与应用超过14年,拥有完全自主知识产权,全球专利总量655余项。 作为眼球追踪技术领域的全球知名品牌,七鑫易维的产品体系覆盖眼动分...
点击进入详情页
本回答由七鑫易维信息技术提供
展开全部
基于oracle:
select p.Cname,(select sum(nvl(TotalPay,0)) from pay where Cname=p.Cname and to_char(SendDate,'yyyy')='2005') as "2005",
(select sum(nvl(TotalPay,0)) from pay where Cname=p.Cname and to_char(SendDate,'yyyy')='2006') as "2006"
from Pay p
group by p.Cname
select p.Cname,(select sum(nvl(TotalPay,0)) from pay where Cname=p.Cname and to_char(SendDate,'yyyy')='2005') as "2005",
(select sum(nvl(TotalPay,0)) from pay where Cname=p.Cname and to_char(SendDate,'yyyy')='2006') as "2006"
from Pay p
group by p.Cname
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
去百度行转列,你这个是典型的行转列
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
没有图啊
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询