MyException - 我的异常网
当前位置:我的异常网» Oracle管理 » 一道面试题解决思路

一道面试题解决思路

www.MyException.Cn  网友分享于:2013-02-08  浏览:12次
一道面试题
前几天碰到一个面试题,当时没有做出来,贴上来看看:
有一张表:Sale (公司销售记录),有如下数据:
-------------------------------
year month saleNumber
-------------------------------
2009 1 1000
2009 2 1200
2009 3 1100
2009 4 1150
2010 1 1300
2010 2 1350
2010 3 1250
2010 4 1350
...
--------------------------------

要求写一段sql语句,显示如下结果:
------------------------------------------
year m1 m2 m3 m4
------------------------------------------
2009 1000 1200 1100 1150
2010 1300 1350 1250 1350
...
------------------------------------------
因为一时没想到该怎么做,所以拿上来请教一下哈。

------解决方案--------------------
SQL code

with t as
(select 2009 as year,1 as month,1000 as saleNumber from dual  UNION ALL
 select 2009, 2, 1200 from dual UNION ALL
 select 2009, 3, 1100 from dual UNION ALL
 select 2009, 4, 1150 from dual UNION ALL
 select 2010, 1, 1300 from dual UNION ALL
 select 2010, 2, 1350 from dual UNION ALL
 select 2010, 3, 1250 from dual UNION ALL
 select 2010, 4, 1350 from dual 
)
select year,sum(m1) m1,sum(m2) m2,sum(m3) m3,sum(m4) m4
  from (select year,
               decode(month,1,saleNumber) as m1,
               decode(month,2,saleNumber) as m2,
               decode(month,3,saleNumber) as m3,
               decode(month,4,saleNumber) as m4
               from t) 
 group by year;

------解决方案--------------------
行转列
------解决方案--------------------
不知道你用的是什么数据库
这个是用oracle的函数decode完成的,希望对lz有用 
select
year,
max(decode(month,'1',salenumber)) as m1 , 
max(decode(month,'2',salenumber)) as m2, 
max(decode(month,'3',salenumber)) as m3 , 
max(decode(month,'4',salenumber)) as m4
from test
GROUP BY year
------解决方案--------------------
4楼的函数做具体题目时可能会有问题的!建议使用3楼答案。
------解决方案--------------------
case when 通用的,干嘛不用呢! 标准sql
------解决方案--------------------
是的..也可以采用8L 说的通用 case when
SQL code

with t as
(select 2009 as year,1 as month,1000 as saleNumber from dual  UNION ALL
 select 2009, 2, 1200 from dual UNION ALL
 select 2009, 3, 1100 from dual UNION ALL
 select 2009, 4, 1150 from dual UNION ALL
 select 2010, 1, 1300 from dual UNION ALL
 select 2010, 2, 1350 from dual UNION ALL
 select 2010, 3, 1250 from dual UNION ALL
 select 2010, 4, 1350 from dual 
)
select year,
       sum(case month when 1 then saleNumber end) as m1,
       sum(case month when 2 then saleNumber end) as m2,
       sum(case month when 3 then saleNumber end) as m3,
       sum(case month when 4 then saleNumber end) as m4
  from t
 group by year;

文章评论

什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
 程序员的样子
程序员的样子
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
中美印日四国程序员比较
中美印日四国程序员比较
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
程序员的鄙视链
程序员的鄙视链
Java程序员必看电影
Java程序员必看电影
程序员必看的十大电影
程序员必看的十大电影
如何成为一名黑客
如何成为一名黑客
代码女神横空出世
代码女神横空出世
我是如何打败拖延症的
我是如何打败拖延症的
旅行,写作,编程
旅行,写作,编程
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
10个调试和排错的小建议
10个调试和排错的小建议
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
程序员和编码员之间的区别
程序员和编码员之间的区别
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
那些争议最大的编程观点
那些争议最大的编程观点
总结2014中国互联网十大段子
总结2014中国互联网十大段子
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
为什么程序员都是夜猫子
为什么程序员都是夜猫子
程序员都该阅读的书
程序员都该阅读的书
我的丈夫是个程序员
我的丈夫是个程序员
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
一个程序员的时间管理
一个程序员的时间管理
编程语言是女人
编程语言是女人
漫画:程序员的工作
漫画:程序员的工作
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
鲜为人知的编程真相
鲜为人知的编程真相
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
老程序员的下场
老程序员的下场
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有