用户名:  密码:
兄弟在线   

标题:全面介绍:Oracle数据库日期处理

作者:佚名 来源:网络 时间:2013-04-03

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

  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秒, 而不是毫秒).

 

[1] [2] [3] [4] [5] [6] 下一页



编辑:admin 总点击 [1832]   评论  0 查看评论
上一篇:Oracle中如何用T-SQL语句建立跟踪
下一篇:不安装ORACLE客户端的系统移植方法
【关闭窗口】
您可能感兴趣的文章
我要评论
          
评论标题:   可以输入250
 
验证数字: 3 + 4 =
兄弟友情提示
· 请自觉遵守国家有关法律、法规,尊重网上道德。
· 兄弟在线坚决抵制不良言行,违者文责自负。
· 如果文章有版权或其他问题等,请联系我们,我们会尽快处理。
· 文章注名来自网络的旨在传播共享信息,不做其它用途;注名原创的本站支持原创,但不代表同意其观点。
· 兄弟在线拥有管理用户与其文章和评论的一切权利,并有权在网站内转载或引用。
兄弟在线
兄弟热门文章
兄弟推荐文章
兄弟站内搜索

兄弟感兴趣的文章
兄弟最新影视