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

 我来答
琬若晨曦
2018-03-31 · TA获得超过8502个赞
知道小有建树答主
回答量:33
采纳率:100%
帮助的人:4824
展开全部

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

downloveh
推荐于2017-11-22 · TA获得超过834个赞
知道小有建树答主
回答量:1548
采纳率:66%
帮助的人:515万
展开全部
问题: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')
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式