执行SQL,提示ORA-01830错误是怎么回事
错误产生原因:date类型不能包含秒以后的精度。
如日期:2012-06-20 21:01:24。
在使用to_date() 函数时有可能出现此错误。
解决办法:
to_date('2012-06-20 21:01:24','yyyy-mm-dd') 是错误的。
to_date( substr('2012-1-1 00:00:00',0,INSTR('2012-1-1 00:00:00', ':', 1, 1)-3),'yyyy-mm-dd') 是正确的。
1、创建存储过程,将一个表中的数据写入另一个表。如下图。
2、测试存储过程,选中存储过程,选择“测试”。
3、“单步进入”,开始进行测试。
4、点击下一步,报错如下,点击确定。
5、再次测试,报错如下。
6、点击“是”,进入如下定位到错误附近,进行检查。定位到该语句“STRSQL := 'SELECT * FROM test1 WHERE ID>0 ' ;”检查,发现,定义 “ STRSQL VARCHAR2(10);”10太小,将其修改为“ STRSQL VARCHAR2(1000);”再次进行测试。
7、再次测试,过程正常。
8、继续执行,耗时27秒,完成执行。
9、检查发现,进入一条数据,错误解决。
select to_date(INVOICE_DATE,'yyyy-mm-dd') from tab;
提示 ORA-01830: 日期格式图片在转换整个输入字符串之前结束 错误
最后查的原因:INVOICE_DATE=‘2005-11-10 00:00:00’的长度大于格式化'yyyy-mm-dd'的长度
解决:(使用substr())
to_date(substr(INVOICE_DATE,1,10),'yyyy-mm-dd')