| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1403 人关注过本帖
标题:sql查询问题
只看楼主 加入收藏
ggvboy
Rank: 4
来 自:沈阳
等 级:贵宾
威 望:10
帖 子:142
专家分:0
注 册:2008-11-7
收藏
 问题点数:0 回复次数:3 
sql查询问题
A表6个字段,分别为:
    emp    dept    year    month    x1    x2   
B表6个字段,分别为:
    emp    dept    year    month    x3    x4
无主键,无非空约束,人员数为根据某一个部门和月份查询出的emp的个数,假如查询的年份为2007年,其中4到12月为2007年的月份,1到3月为2008年的月份。

查出如下结构

        4月    5月    6月    7月    8月    9月    10月    11月    12月    1月    2月    3月

人员数
(x1+x2)
(x3+x4)   

解决不了没工作,要效率贴,希望各位巨侠帮忙!
搜索更多相关主题的帖子: oracle sql 查询 
2008-11-26 16:01
gdy0349
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:上海
等 级:版主
威 望:11
帖 子:223
专家分:676
注 册:2008-11-12
收藏
得分:0 
方法笨了点,但能解决问题
select a.*,b.* from(
select a.emp,decode(a.month,'04',x1+x2),decode(a.month,'05',x1+x2),decode(a.month,'06',x1+x2),decode(a.month,'07',x1+x2),decode(a.month,'08',x1+x2),decode(a.month,'09',x1+x2)
,decode(a.month,'10',x1+x2),decode(a.month,'11',x1+x2),decode(a.month,'12',x1+x2) from a where a.year=2007) a(
select a.emp,decode(a.month,'01',x1+x2),decode(a.month,'02',x1+x2),decode(a.month,'03',x1+x2) from a where a.year=2008) b where a.emp=b.emp
2008-11-26 17:52
ggvboy
Rank: 4
来 自:沈阳
等 级:贵宾
威 望:10
帖 子:142
专家分:0
注 册:2008-11-7
收藏
得分:0 
的确是笨,但不能解决问题,我只是把SQL要查的几个字段说出来,开始我差不多就是这么写的,写了1千多行,查处数据耗时4秒多,在CSDN上也没有好的结果,我就是想按(4,5,6,7,8,9,10,11,12,1,2,3)这个排序,能简单点,头疼。
2008-12-09 16:48
快速回复:sql查询问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.013519 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved