您当前的位置: 首页 >  oracle

qq_34412985

暂无认证

  • 0浏览

    0关注

    1061博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

Oracle错误: ORA-01722 无效数字

qq_34412985 发布时间:2019-11-28 14:09:32 ,浏览量:0

程序或者Oracle数据库出现“ORA-01722 无效数字” 错误

原因:

1、Oracle数据库的字段为Number类型,如果操作数据库的SQL语句中该字段所携带的数据不是数字类型,Oracle数据库会自动将该字段携带的数据转换成Number类型,但是最后转换不成功就会报错。

例如SQL语句中该字段携带的数据为“123”,那么Oracle可以成功转换,如果该字段携带的数据为“2019年6月10日”,Oracle转换失败,报无效数字错误!

例如:select to_char('2019-10-15','yyyy-MM-dd')sys_date from dual

         实际sql: select to_char(to_char(2019-10-15,'yyyy-MM-dd'))sys_date from dual

2、SQL语句中多表关联时,关联条件字段的值Oracle会自动转成数字类型,如果转换失败报错。

例如A表的主键ID(Number类型)和B表的某个字段A_ID(Varchar2类型),关联语句:from A left join B on A.ID = B.A_ID,Oracle会首先将A_ID转换成Number类型,如果在插入数据或者修改数据的时候将A_ID的值变成非数字(英文、汉字或者夹杂特殊字符),这时候Oracle转换就会报错。

关注
打赏
1653291990
查看更多评论
立即登录/注册

微信扫码登录

0.1875s