免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4103 | 回复: 2
打印 上一主题 下一主题

[分享] oracle处理考勤时间,拆分考勤时间段的sql语句(转载) [复制链接]

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2015-06-24 22:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-06-23 09:22 |只看该作者 |倒序浏览
最近一直在用mysql数据库做云项目,有段时间没有接触oracle了,昨天有朋友叫我帮忙用oracle处理一个考勤记录的需求,我在考虑如何尽量精简实现上面花了一些时间。于是把这个实现做个总结。

需求如下:

rownum为奇数的为进厂时间,偶数的为离场时间
第一个奇数行的时间被第一个偶数行相减,以此类推
将上面两步产生的时间结果集相加得出总时间作为当天考勤时间
最终能和别的表联合起来形成这样的展示:

要我实现的是如何把时间一列的数据拆分成为两列来显示:

原来一列是这样的:

要实现的拆分的效果是这样的:

实现方式如下:

首先创建一个时间表(当然这里我关注的只是scan_time这个字段,其他字段不用理会):
  1. create table CMIS_PERSON_FI_DETAIL_TB
  2. (
  3.   detail_id    NUMBER(20) not null,
  4.   scan_time    DATE,
  5.   person_fk_id NUMBER(20) not null
  6. )
复制代码
其次,插入数据,插入数据之后的效果是这样的:

最后编写sql进行实现,实现的sql语句如下所示:
  1. select max(a) in_time, max(b) out_time
  2.   from (select decode(mod(rownum, 2), 1, scan_time) a,
  3.                decode(mod(rownum, 2), 0, scan_time) b,
  4.                round(rownum / 2) c
  5.           from CMIS_PERSON_FI_DETAIL_TB)
  6. group by c
  7. order by c;
复制代码
运行sql,得到了想要的效果,如下所示:

论坛徽章:
59
2015七夕节徽章
日期:2015-08-24 11:17:25ChinaUnix专家徽章
日期:2015-07-20 09:19:30每周论坛发贴之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38荣誉版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年纪念徽章
日期:2015-07-20 11:05:27IT运维版块每日发帖之星
日期:2015-07-20 11:05:34操作系统版块每日发帖之星
日期:2015-07-20 11:05:36程序设计版块每日发帖之星
日期:2015-07-20 11:05:40数据库技术版块每日发帖之星
日期:2015-07-20 11:05:432015年辞旧岁徽章
日期:2015-07-20 11:05:44
2 [报告]
发表于 2015-07-20 11:18 |只看该作者
不错。时间久了就用分区表。

论坛徽章:
7
亥猪
日期:2013-10-10 17:00:29辰龙
日期:2013-10-12 16:23:19卯兔
日期:2013-11-18 17:01:27金牛座
日期:2014-09-09 10:17:052015七夕节徽章
日期:2015-08-21 11:06:172015亚冠之柏太阳神
日期:2015-09-25 13:56:42数据库技术版块每日发帖之星
日期:2016-08-06 06:20:00
3 [报告]
发表于 2015-07-24 09:25 |只看该作者
假如遇到一个打卡打几次的。这个怎么算。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP