执行SQL,提示ORA-01830错误是怎么回事

发布网友 发布时间:2022-04-24 16:07

我来回答

2个回答

热心网友 时间:2022-04-13 09:10

错误产生原因: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、检查发现,进入一条数据,错误解决。

热心网友 时间:2022-04-13 10:28

问题:varchar2类型转换成date类型
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')

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com