oracle处理考勤时间,拆分考勤时间段的sql语句
生活随笔
收集整理的這篇文章主要介紹了
oracle处理考勤时间,拆分考勤时间段的sql语句
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
最近一直在用mysql數據庫做云項目,有段時間沒有接觸oracle了,昨天有朋友叫我幫忙用oracle處理一個考勤記錄的需求,我在考慮如何盡量精簡實現上面花了一些時間。于是把這個實現做個總結。
需求如下:
最終能和別的表聯合起來形成這樣的展示:
?
| 人員 | 日期 | 工時 | 入廠時間 | 出廠時間 |
| 張三 | 2015/6/18 | 9小時30分鐘 | 8:00:00 | 10:30:00 |
| 11:00:00 | 12:30:00 | |||
| 13:30:00 | 17:30:00 | |||
| 18:00:00 | 18:30:00 | |||
| 19:00:00 | 19:30:00 | |||
| 20:00:00 | 20:30:00 | |||
| 李四 | … | … | .. | .. |
?要我實現的是如何把時間一列的數據拆分成為兩列來顯示:
原來一列是這樣的:
?
要實現的拆分的效果是這樣的:
實現方式如下:
首先創建一個時間表(當然這里我關注的只是scan_time這個字段,其他字段不用理會):
create table CMIS_PERSON_FI_DETAIL_TB (detail_id NUMBER(20) not null,scan_time DATE,person_fk_id NUMBER(20) not null )其次,插入數據,插入數據之后的效果是這樣的:
最后編寫sql進行實現,實現的sql語句如下所示:
select max(a) in_time, max(b) out_timefrom (select decode(mod(rownum, 2), 1, scan_time) a,decode(mod(rownum, 2), 0, scan_time) b,round(rownum / 2) cfrom CMIS_PERSON_FI_DETAIL_TB)group by corder by c;運行sql,得到了想要的效果,如下所示:
轉載于:https://www.cnblogs.com/longshiyVip/p/4590956.html
總結
以上是生活随笔為你收集整理的oracle处理考勤时间,拆分考勤时间段的sql语句的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 讀後感
- 下一篇: 关于我自己的三个层次