出现 无法转换为内部表示 异常

本文介绍了一种因数据库字段类型与Java属性类型不匹配导致的异常。具体表现为手动输入VARCHAR2类型的数据到引用自NUMBER类型字段时引发的问题,并提供了解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原因:数据库里的字段类型与Java里映射该字段属性的类型不能对应转换,例如数据库里字段类型为Varchar2,而Java定义的类型为Long;或者数据库里为Number,而Java定义的对应属性类型为String。
真实情况:在数据库中,该表有一个CREATED_BY字段。该字段在当前表中类型为VARCHAR2(20)。但是实际上,该字段引用自user表,类型为NUMBER(19)。在编译时,javaBean会自动将两者进行转换对应。出现问题的原因在于,手动在下表中增加一条数据,CREATED_BY字段为“tester”,这导致了不能从“tester”转化为一个NUMBER类型的字段。因此出现该异常。在更改了该字段为数据库中已有user的ID,例如“30”,之后,该异常消失。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值