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

 我来答
琬若晨曦
推荐于2019-10-17 · TA获得超过8502个赞
知道小有建树答主
回答量:33
采纳率:100%
帮助的人:4822
展开全部

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

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式