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