常用函数--时间函数

    经常会碰到一些程序执行得慢,这时需要通过时间来找找出这些问题程序进行处理。如果找呢?这里会用到与时间相关的一些函数,具体如下:

 
 
31. 更改日期顯示的format  
4 ex.  
5 ALTER SESSION SET NLS_DATE_FORMAT = 'YYYY/MM/DD';     
6 階段作業已被更改     
7            
8 select sysdate from dual;     
9            
10 SYSDATE     
11 ----------     
12 2007/09/20     
13            
14 --只對目前session有效,一個 connect 視為一個 session  
15 
162. 日期 + 數值  
17 ex.  
18 select sysdate + 10 from dual;  
19   
20 SYSDATE+10  
21 ----------  
22 01-OCT-07   
23         
243. 日期 - 數值  
25 ex.  
26 select sysdate - 10 from dual;  
27 
28 SYSDATE-10  
29 ----------  
30 11-SEP-07  
31 
324. 日期相減得到日期差  
33 ex.  
34 select sysdate - to_date('20070901','yyyymmdd') aa from dual;  
35   
36           AA  
37 -------------  
38   20.4508218    
39   
40 --◎ 包含時間,所以有小數  
41 --◎ 可做日期欄位的計算  
42   
43 select trunc(sysdate - to_date('20070901','yyyymmdd')) aa from dual;  
44   
45        AA  
46 ----------  
47        20  
48 --使用trunc取整數,得到日期  
49 
505. 日期相減得到小時差  
51 ex.  
52 select trunc((sysdate - to_date('20070901','yyyymmdd'))*24) aa from dual;  
53 
54         AA  
55 ----------  
56        490  
57 
586. 日期相減得到分鐘差  
59 ex.  
60 select trunc((sysdate - to_date('20070901','yyyymmdd'))*24*60) aa from dual;  
61   
62       AA  
63 ---------  
64     29459  
65 
667. 日期相減得到秒數差  
67 ex.  
68 select trunc((sysdate - to_date('20070901','yyyymmdd'))*24*60*60) aa from dual;  
69 
70        AA  
71 ----------  
72    1767606  
73 
748. 日期 + n小時  
75 ex.  
76 select to_char(sysdate,'YYYY/MM/DD HH24:MI:SS') aa from dual;  
77   
78 AA  
79 --------------------  
80 2007/09/21 11:03:47  --系統時間  
81   
82 select to_char(sysdate+2/24,'YYYY/MM/DD HH24:MI:SS') aa from dual;  
83 
84 AA  
85 --------------------  
86 2007/09/21 13:03:47  --加2小時(理論值)  
87 
889. 日期 + n分鐘   
89 ex.  
90 select to_char(sysdate+10/1440,'YYYY/MM/DD HH24:MI:SS') aa from dual;  
91 
92 AA  
93 --------------------  
94 2007/09/21 11:13:47  --加10分鐘(理論值)  
95 
9610. 日期+ n秒鐘  
97 ex.  
98 select to_char(sysdate+10/86400,'YYYY/MM/DD HH24:MI:SS') aa from dual;  
99      
100 AA  
101 --------------------  
102

 2007/09/21 11:13:57  --加10秒鐘(理論值) 

实例:

 select run_proc_name,
       run_status,
       run_start_time,
       run_end_time,
       (run_end_time - run_start_time) * 24 * 60 as use_minutes
 from log_proc_run
 where trunc(run_start_time) = trunc(sysdate)
 order by use_time desc

 

参考:http://blog.blueshop.com.tw/pili9141/articles/52501.aspx

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/15720542/viewspace-608450/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/15720542/viewspace-608450/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值