亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 4280 | 回復(fù): 2
打印 上一主題 下一主題

[分享] oracle處理考勤時間,拆分考勤時間段的sql語句(轉(zhuǎn)載) [復(fù)制鏈接]

論壇徽章:
1
數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-06-24 22:20:00
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2015-06-23 09:22 |只看該作者 |倒序瀏覽
最近一直在用mysql數(shù)據(jù)庫做云項目,有段時間沒有接觸oracle了,昨天有朋友叫我?guī)兔τ胦racle處理一個考勤記錄的需求,我在考慮如何盡量精簡實現(xiàn)上面花了一些時間。于是把這個實現(xiàn)做個總結(jié)。

需求如下:

rownum為奇數(shù)的為進(jìn)廠時間,偶數(shù)的為離場時間
第一個奇數(shù)行的時間被第一個偶數(shù)行相減,以此類推
將上面兩步產(chǎn)生的時間結(jié)果集相加得出總時間作為當(dāng)天考勤時間
最終能和別的表聯(lián)合起來形成這樣的展示:

要我實現(xiàn)的是如何把時間一列的數(shù)據(jù)拆分成為兩列來顯示:

原來一列是這樣的:

要實現(xiàn)的拆分的效果是這樣的:

實現(xiàn)方式如下:

首先創(chuàng)建一個時間表(當(dāng)然這里我關(guān)注的只是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. )
復(fù)制代碼
其次,插入數(shù)據(jù),插入數(shù)據(jù)之后的效果是這樣的:

最后編寫sql進(jìn)行實現(xiàn),實現(xiàn)的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;
復(fù)制代碼
運行sql,得到了想要的效果,如下所示:

論壇徽章:
59
2015七夕節(jié)徽章
日期:2015-08-24 11:17:25ChinaUnix專家徽章
日期:2015-07-20 09:19:30每周論壇發(fā)貼之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38榮譽版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年紀(jì)念徽章
日期:2015-07-20 11:05:27IT運維版塊每日發(fā)帖之星
日期:2015-07-20 11:05:34操作系統(tǒng)版塊每日發(fā)帖之星
日期:2015-07-20 11:05:36程序設(shè)計版塊每日發(fā)帖之星
日期:2015-07-20 11:05:40數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-07-20 11:05:432015年辭舊歲徽章
日期:2015-07-20 11:05:44
2 [報告]
發(fā)表于 2015-07-20 11:18 |只看該作者
不錯。時間久了就用分區(qū)表。

論壇徽章:
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七夕節(jié)徽章
日期:2015-08-21 11:06:172015亞冠之柏太陽神
日期:2015-09-25 13:56:42數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2016-08-06 06:20:00
3 [報告]
發(fā)表于 2015-07-24 09:25 |只看該作者
假如遇到一個打卡打幾次的。這個怎么算。
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP