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

原因:

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

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

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转换就会报错。

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐