oracl处理日期sql

1、转换函数 
与date操作关系最大的就是两个转换函数:to_date(),to_char() 
to_date() 作用将字符类型按一定格式转化为日期类型: 
具体用法:to_date('2004-11-27','yyyy-mm-dd'),前者为字符串,后者为转换日期格式,注意,前后两者要以一对应。 
如;to_date('2004-11-27 13:34:43', 'yyyy-mm-dd hh24:mi:ss') 将得到具体的时间 

多种日期格式: 
YYYY:四位表示的年份 
YYY,YY,Y:年份的最后三位、两位或一位,缺省为当前世纪 
MM:01~12的月份编号 
MONTH:九个字符表示的月份,右边用空格填补 
MON:三位字符的月份缩写 
WW:一年中的星期 
D:星期中的第几天 
DD:月份中的第几天 
DDD:年所中的第几天 
DAY:九个字符表示的天的全称,右边用空格补齐 
HH,HH12:一天中的第几个小时,12进制表示法 
HH24:一天中的第几个小时,取值为00~23 
MI:一小时中的分钟 
SS:一分钟中的秒 
SSSS:从午夜开始过去的秒数 

to_char():将日期转按一定格式换成字符类型 

SQL> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') time from dual; 


即把当前时间按yyyy-mm-dd hh24:mi:ss格式转换成字符类型 

在oracle中处理日期:

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 .... 

2、两个日期间的天数 

select floor(sysdate - to_date('20020405','yyyymmdd')) from dual; 

3、时间为null的用法 

select id, active_date from table1 
UNION 
select 1, TO_DATE(null) from dual; 


注意要用TO_DATE(null) ;

4、获得小时数 

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 


获取年月日与此类似 。

5、add_months()用于从一个日期值增加或减少一些月份 
date_value:=add_months(date_value,number_of_months) 
例: 

SQL> select add_months(sysdate,12) "Next Year" from dual; 

Next Year 
---------- 
13-11月-04 

SQL> select add_months(sysdate,112) "Last Year" from dual; 

Last Year 
---------- 
13-3月 -13 

6、last_day()返回包含了日期参数的月份的最后一天的日期 
date_value:=last_day(date_value) 

SQL> select last_day(date'2000-02-01') "Leap Yr?" from dual; 

Leap Yr? 
---------- 
29-2月 -00 

SQL> select last_day(sysdate) "Last day of this month" from dual; 

Last day o 
---------- 
30-11月-0

7、months_between()判断两个日期之间的月份数量 
number_value:=months_between(date_value,date_value) 

SQL> select months_between(sysdate,date'1971-05-18') from dual; 

MONTHS_BETWEEN(SYSDATE,DATE'1971-05-18') 
---------------------------------------- 
389.855143 

SQL> select months_between(sysdate,date'2001-01-01') from dual; 

MONTHS_BETWEEN(SYSDATE,DATE'2001-01-01') 
---------------------------------------- 
34.4035409 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦__

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值