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语句的全部內容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: 讀後感
 - 下一篇: 关于我自己的三个层次