Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2889110
  • 博文数量: 200
  • 博客积分: 2413
  • 博客等级: 大尉
  • 技术积分: 3067
  • 用 户 组: 普通用户
  • 注册时间: 2011-04-01 22:07
文章分类

全部博文(200)

文章存档

2018年(2)

2017年(8)

2016年(35)

2015年(14)

2014年(20)

2013年(24)

2012年(53)

2011年(44)

分类: Oracle

2013-06-19 18:00:17

工作中常会使用to_date函数,将文本转换成日期格式
select to_date('2012-01-03 00:00:00','yyyy-mm-dd hh24:mi:ss') from dual;
 
如果格式有误,to_date()函数就会报错
select to_date('00000101','yyyymmdd') from dual;
ORA-01841: (完整) 年份值必须介于 -4713 和 +9999 之间, 且不为 0
01841. 00000 -  "(full) year must be between -4713 and +9999, and not be 0"
*Cause:    Illegal year entered
*Action:   Input year in the specified range
 
下面的场景遇到这个错误解决起来很麻烦
insert into a
select to_date(log_time,'yyyy-mm-dd hh24:mi:ss')
from b;
如果b表中log_time列有错误数据,就会返回上面的错误。
 
使用函数处理日期转换异常是个不错的选择。
通过日期转换函数可以将正确格式的转换成日期,不正确的做异常处理,输出空。
 
--函数:异常处理日期转换错误
create or replace function  date_fun(p_str in NVARCHAR2) return date is
v_ret date;
 begin  
     begin
      v_ret:=to_date(p_str,'yyyy-mm-dd hh24:mi:ss');
      exception
       when OTHERS then  null;
     end;  
     return v_ret;             
  end;
  /
阅读(5852) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~