久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

怎樣在Oracle9i中計算時間差

瀏覽:64日期:2023-11-27 16:40:23
計算時間差是Oracle DATA數(shù)據(jù)類型的一個常見問題。Oracle支持日期計算,你可以創(chuàng)建諸如“日期1-日期2”這樣的表達式來計算這兩個日期之間的時間差。 一旦你發(fā)現(xiàn)了時間差異,你可以使用簡單的技巧來以天、小時、分鐘或者秒為單位來計算時間差。為了得到數(shù)據(jù)差,你必須選擇合適的時間度量單位,這樣就可以進行數(shù)據(jù)格式隱藏。 使用完善復雜的轉換函數(shù)來轉換日期是一個誘惑,但是你會發(fā)現(xiàn)這不是最好的解決方法。round(to_number(end-date-start_date))- 消逝的時間(以天為單位)round(to_number(end-date-start_date)*24)- 消逝的時間(以小時為單位)round(to_number(end-date-start_date)*1440)- 消逝的時間(以分鐘為單位)顯示時間差的默認模式是什么?為了找到這個問題的答案,讓我們進行一個簡單的SQL *Plus查詢。SQL> select sysdate-(sysdate-3) from dual;SYSDATE-(SYSDATE-3)-------------------3這里,我們看到了Oracle使用天來作為消逝時間的單位,所以我們可以很輕易的使用轉換函數(shù)來把它轉換成小時或者分鐘。然而,當分鐘數(shù)不是一個整數(shù)時,我們就會碰到放置小數(shù)點的問題。Select (sysdate-(sysdate-3.111))*1440 from dual; (SYSDATE-(SYSDATE-3.111))*1440 ------------------------------ 4479.83333當然,我們可以用ROUND函數(shù)(即取整函數(shù))來解決這個問題,但是要記住我們必須首先把DATE數(shù)據(jù)類型轉換成NUMBER數(shù)據(jù)類型。Selectround(to_number(sysdate-(sysdate-3.111))*1440)fromdual;ROUND(TO_NUMBER(SYSDATE-(SYSDATE-3.111))*1440)---------------------------------------------4480我們可以用這些函數(shù)把一個消逝時間近似轉換成分鐘并把這個值寫入Oracle表格中。在這個例子里,我們有一個離線(logoff)系統(tǒng)級觸發(fā)機制來計算已經(jīng)開始的會話時間并把它放入一個Oracle STATSPACK USER_LOG擴展表格之中。 Updateperfstat.stats$user_logsetelapsed_minutes =round(to_number(logoff_time-logon_time)*1440)whereuser = user_idandelapsed_minutes is NULL;
主站蜘蛛池模板: 济阳县| 涞源县| 松江区| 巩留县| 九龙坡区| 阜城县| 江陵县| 监利县| 陆丰市| 潮州市| 无极县| 大方县| 大冶市| 赤城县| 喜德县| 铜陵市| 三穗县| 莱州市| 弥勒县| 河南省| 绥德县| 横峰县| 鲁甸县| 福建省| 石阡县| 兴仁县| 旬阳县| 安顺市| 隆林| 淮安市| 怀宁县| 常熟市| 浮梁县| 新安县| 莱芜市| 三门县| 右玉县| 绥阳县| 天镇县| 盐边县| 芜湖市|