ORA-01722 无效数字

当Oracle数据库遇到'ORA-01722无效数字'错误,通常是由于尝试将非数字数据转换为Number类型字段导致的。此错误可能出现在字段值包含字母、日期或其他非数字字符时。解决方法包括确保插入或更新的数据符合字段类型,或者在SQL语句中使用字符串比较。在进行多表关联时,也要注意字段类型匹配,避免因隐式类型转换失败而引发错误。
摘要由CSDN通过智能技术生成

程序或者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转换就会报错。

或者同时转换为字符串类型(字段a||'' = 字段b||'',都连接一个空字符串使之变成字符串类型)。   ================   AND o.orgcode||''  IN (

简单的来说 in ( fieldvalue1,fieldvalue2)

在数据库中表存的值有非数字,是英文字母

in ( 'fieldvalue1','fieldvalue2')

记得在程序添加引号

转载地址:https://blog.csdn.net/a990914093/article/details/91382183

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值