设为首页 收藏本站
查看: 707|回复: 0

[经验分享] 在oracle中处理日期大全

[复制链接]

尚未签到

发表于 2016-7-27 01:06:26 | 显示全部楼层 |阅读模式
TO_DATE格式      
Day:      
dd   number   12      
dy   abbreviated   fri      
day   spelled   out   friday      
ddspth   spelled   out,   ordinal   twelfth      
Month:      
mm   number   03      
mon   abbreviated   mar      
month   spelled   out   march      
Year:      
yy   two   digits   98      
yyyy   four   digits   1998      
24小时格式下时间范围为:   0:00:00   -   23:59:59....      
12小时格式下时间范围为:   1:00:00   -   12:59:59   ....      
1.      
日期和字符转换函数用法(to_date,to_char)      
2.      
select   to_char(   to_date(222,'J'),'Jsp')   from   dual      
显示Two   Hundred   Twenty-Two      
3.      
求某天是星期几      
select   to_char(to_date('2002-08-26','yyyy-mm-dd'),'day')   from   dual;      
星期一      
select   to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE   =   American')   from   dual;      
monday      
设置日期语言      
ALTER   SESSION   SET   NLS_DATE_LANGUAGE='AMERICAN';      
也可以这样      
TO_DATE   ('2002-08-26',   'YYYY-mm-dd',   'NLS_DATE_LANGUAGE   =   American')      
4.      
两个日期间的天数      
select   floor(sysdate   -   to_date('20020405','yyyymmdd'))   from   dual;      
5.   时间为null的用法      
select   id,   active_date   from   table1      
UNION      
select   1,   TO_DATE(null)   from   dual;      
注意要用TO_DATE(null)      
6.      
a_date   between   to_date('20011201','yyyymmdd')   and   to_date('20011231','yyyymmdd')      
那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。      
所以,当时间需要精确的时候,觉得to_char还是必要的      
7.   日期格式冲突问题      
输入的格式要看你安装的ORACLE字符集的类型,   比如:   US7ASCII,   date格式的类型就是:   '01-Jan-01'      
alter   system   set   NLS_DATE_LANGUAGE   =   American      
alter   session   set   NLS_DATE_LANGUAGE   =   American      
或者在to_date中写      
select   to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE   =   American')   from   dual;      
注意我这只是举了NLS_DATE_LANGUAGE,当然还有很多,      
可查看      
select   *   from   nls_session_parameters      
select   *   from   V$NLS_PARAMETERS      
8.      
select   count(*)      
from   (   select   rownum-1   rnum      
from   all_objects      
where   rownum   <=   to_date('2002-02-28','yyyy-mm-dd')   -   to_date('2002-      
02-01','yyyy-mm-dd')+1      
)      
where   to_char(   to_date('2002-02-01','yyyy-mm-dd')+rnum-1,   'D'   )      
not      
in   (   '1',   '7'   )      
查找2002-02-28至2002-02-01间除星期一和七的天数      
在前后分别调用DBMS_UTILITY.GET_TIME,   让后将结果相减(得到的是1/100秒,   而不是毫秒).      
9.      
select   months_between(to_date('01-31-1999','MM-DD-YYYY'),      
to_date('12-31-1998','MM-DD-YYYY'))   "MONTHS"   FROM   DUAL;      
1      
select   months_between(to_date('02-01-1999','MM-DD-YYYY'),      
to_date('12-31-1998','MM-DD-YYYY'))   "MONTHS"   FROM   DUAL;      
1.03225806451613      
10.   Next_day的用法      
Next_day(date,   day)      
Monday-Sunday,   for   format   code   DAY      
Mon-Sun,   for   format   code   DY      
1-7,   for   format   code   D      
11      
select   to_char(sysdate,'hh:mi:ss')   TIME   from   all_objects      
注意:第一条记录的TIME   与最后一行是一样的      
可以建立一个函数来处理这个问题      
create   or   replace   function   sys_date   return   date   is      
begin      
return   sysdate;      
end;      
select   to_char(sys_date,'hh:mi:ss')   from   all_objects;      
12.      
获得小时数      
SELECT   EXTRACT(HOUR   FROM   TIMESTAMP   '2001-02-16   2:38:40')   from   offer      
SQL>   select   sysdate   ,to_char(sysdate,'hh')   from   dual;      
SYSDATE   TO_CHAR(SYSDATE,'HH')      
--------------------   ---------------------      
2003-10-13   19:35:21   07      
SQL>   select   sysdate   ,to_char(sysdate,'hh24')   from   dual;      
SYSDATE   TO_CHAR(SYSDATE,'HH24')      
--------------------   -----------------------      
2003-10-13   19:35:21   19      
获取年月日与此类似      
13.      
年月日的处理      
select   older_date,      
newer_date,      
years,      
months,      
abs(      
trunc(      
newer_date-      
add_months(   older_date,years*12+months   )      
)      
)   days      
from   (   select      
trunc(months_between(   newer_date,   older_date   )/12)   YEARS,      
mod(trunc(months_between(   newer_date,   older_date   )),      
12   )   MONTHS,      
newer_date,      
older_date      
from   (   select   hiredate   older_date,      
add_months(hiredate,rownum)+rownum   newer_date      
from   emp   )      
)      
14.      
处理月份天数不定的办法      
select   to_char(add_months(last_day(sysdate)   +1,   -2),   'yyyymmdd'),last_day(sysdate)   from   dual      
16.      
找出今年的天数      
select   add_months(trunc(sysdate,'year'),   12)   -   trunc(sysdate,'year')   from   dual      
闰年的处理方法      
to_char(   last_day(   to_date('02'   ||   :year,'mmyyyy')   ),   'dd'   )      
如果是28就不是闰年      
17.      
yyyy与rrrr的区别      
'YYYY99   TO_C      
-------   ----      
yyyy   99   0099      
rrrr   99   1999      
yyyy   01   0001      
rrrr   01   2001      
18.不同时区的处理      
select   to_char(   NEW_TIME(   sysdate,   'GMT','EST'),   'dd/mm/yyyy   hh:mi:ss')   ,sysdate      
from   dual;      
19.      
5秒钟一个间隔      
Select   TO_DATE(FLOOR(TO_CHAR(sysdate,'SSSSS')/300)   *   300,'SSSSS')   ,TO_CHAR(sysdate,'SSSSS')      
from   dual      
2002-11-1   9:55:00   35786      
SSSSS表示5位秒数      
20.      
一年的第几天      
select   TO_CHAR(SYSDATE,'DDD'),sysdate   from   dual      
310   2002-11-6   10:03:51      
21.计算小时,分,秒,毫秒      
select      
Days,      
A,      
TRUNC(A*24)   Hours,      
TRUNC(A*24*60   -   60*TRUNC(A*24))   Minutes,      
TRUNC(A*24*60*60   -   60*TRUNC(A*24*60))   Seconds,      
TRUNC(A*24*60*60*100   -   100*TRUNC(A*24*60*60))   mSeconds      
from      
(      
select      
trunc(sysdate)   Days,      
sysdate   -   trunc(sysdate)   A      
from   dual      
)      
select   *   from   tabname      
order   by   decode(mode,'FIFO',1,-1)*to_char(rq,'yyyymmddhh24miss');      
//      
floor((date2-date1)   /365)   作为年      
floor((date2-date1,   365)   /30)   作为月      
mod(mod(date2-date1,   365),   30)作为日.      
23.next_day函数      
next_day(sysdate,6)是从当前开始下一个星期五。后面的数字是从星期日开始算起。      
1   2   3   4   5   6   7      
日   一   二   三   四   五   六   
在论坛中常常看到有对oracle中时间运算提问的问题,今天有时间,看了看以前各位兄弟的贴子,整理了一下,并作了个示例,希望会对大家有帮助。     
首先感谢ern、eric.li及各版主还有热心的兄弟们     
内容如下:     
1、oracle支持对日期进行运算     
2、日期运算时是以天为单位进行的     
3、当需要以分秒等更小的单位算值时,按时间进制进行转换即可     
4、进行时间进制转换时注意加括号(见示例中红色括号),否则会出问题     
SQL>   alter   session   set   nls_date_format='yyyy-mm-dd   hh:mi:ss';     
会话已更改。     
SQL>   set   serverout   on     
SQL>   declare     
2   DateValue   date;     
3   begin     
4   select   sysdate   into   DateValue   from   dual;     
5   dbms_output.put_line('源时间:'||to_char(DateValue));     
6   dbms_output.put_line('源时间减1天:'||to_char(DateValue-1));     
7   dbms_output.put_line('源时间减1天1小时:'||to_char(DateValue-1-1/24));     
8   dbms_output.put_line('源时间减1天1小时1分:'||to_char(DateValue-1-1/24-1/(24*60)));     
9   dbms_output.put_line('源时间减1天1小时1分1秒:'||to_char(DateValue-1-1/24-1/(24*60)-1/(24*60*6     
0)));     
10   end;     
11   /     
源时间:2003-12-29   11:53:41     
源时间减1天:2003-12-28   11:53:41     
源时间减1天1小时:2003-12-28   10:53:41     
源时间减1天1小时1分:2003-12-28   10:52:41     
源时间减1天1小时1分1秒:2003-12-28   10:52:40     
PL/SQL   过程已成功完成。     
SQL>
查看server端的字符集:
select * from V$NLS_PARAMETERS
parameter value
NLS_LANGUAGE SIMPLIFIED CHINESE
NLS_TERRITORY CHINA
…. ….
NLS_CHARACTERSET WE8MSWIN1252
NLS_SORT BINARY
Oracle通过NLS_LANG来设置客户端的情况,NLS_LANG由以下部分组成:NLS_LANG=<Language>_<Territory>.<Clients Characterset>
打开注册表:HKEY_LOCAL_MACHINE->SOFTWARE->ORACLE
修改注册表下nls_lang键值(包括oracle下的、ID0下的和HOME0下的nls_lang都修改了)
将NLS_LANG的键值设为:SIMPLIFIED CHINESE_CHINA.WE8MSWIN1252
再往数据库中插入汉字就ok了。。。
查看表的建表记录
SELECT   OBJECT_NAME,    --对象名  
 OBJECT_TYPE,    --对象类型  
 TO_CHAR(CREATED,   'YYYY-Mon-DD   HH24:MI')   CREATE_TIME, --创建时间  
 TO_CHAR(LAST_DDL_TIME,   'YYYY-Mon-DD   HH24:MI')   MOD_TIME,     --修改时间
 TIMESTAMP,                  --时间戳  
 STATUS                    --状态  
 FROM   USER_OBJECTS  
 WHERE   to_char(LAST_DDL_TIME,'yyyymmdd')>'20070202';
从字符串中选择出数字
--方法一:translate函数
select translate('23456中国3-00=.,45','0123456789'||'23456中国3-00=.,45','0123456789') from dual;
--方法二:自定义函数。
create or replace function f_filter_str(var_str varchar) return varchar
is
var_str_new varchar2(2000);
begin
for i in 1..length(var_str) loop
if ascii(substr(var_str,i,1))>=48 and ascii(substr(var_str,i,1))<=57 then
var_str_new := var_str_new || substr(var_str,i,1);
end if;
end loop;
return var_str_new;
end f_filter_str;
/
select f_filter_str('23456中国3-00=.,45') from dual;
--方法三:正则表达式
--oracle10g以上版本
select regexp_replace('23456中国3-00=.,45','[^0-9]') from dual;
结果:
2345630045
select regexp_substr(regexp_replace('ASD45XXGG31KK/22','[^0-9]+','-'),'([0-9]+-?)+') from dual;
结果:
45-31-22
结果:

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-249781-1-1.html 上篇帖子: Oracle-07445[kgghash]:Oracle BUG导致更新LOB字段时进程被KILL掉 下篇帖子: ORACLE用户自动被锁解决方法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表