日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

oracle处理考勤时间,拆分考勤时间段的sql语句

發布時間:2023/12/9 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle处理考勤时间,拆分考勤时间段的sql语句 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

最近一直在用mysql數據庫做云項目,有段時間沒有接觸oracle了,昨天有朋友叫我幫忙用oracle處理一個考勤記錄的需求,我在考慮如何盡量精簡實現上面花了一些時間。于是把這個實現做個總結。

需求如下:

  • rownum為奇數的為進廠時間,偶數的為離場時間
  • 第一個奇數行的時間被第一個偶數行相減,以此類推
  • 將上面兩步產生的時間結果集相加得出總時間作為當天考勤時間
  • 最終能和別的表聯合起來形成這樣的展示:

    ?

    人員

    日期

    工時

    入廠時間

    出廠時間

    張三

    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语句的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。