没有合适的资源?快使用搜索试试~ 我知道了~
oracle中日期格式总结.pdf
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 157 浏览量
2021-12-16
12:02:20
上传
评论
收藏 615KB PDF 举报
温馨提示
试读
16页
。。。
资源推荐
资源详情
资源评论
路漫漫其修远兮,吾将上下而求索 - 百度文库
oracle 日期格式总结在 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;
1
路漫漫其修远兮,吾将上下而求索 - 百度文库
星期一
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'
2
路漫漫其修远兮,吾将上下而求索 - 百度文库
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'),
3
路漫漫其修远兮,吾将上下而求索 - 百度文库
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')
4
剩余15页未读,继续阅读
资源评论
苦茶子12138
- 粉丝: 1w+
- 资源: 6万+
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功