Bootstrap

JDBC结果集转pojo,Bigint类型的字段映射成Java中Integer的问题

    在MySql中给一个用户Id字段设置为Bigint类型,使用JDBC在完成ORM的时候,以为其可以自动转换为Integer,因为我的POJO类id使用的就是Integer。但事实是,我在测试的时候,发现报错,明明数据库中id是有值的,为什么取不到?原因在于MySql的Bigint类型映射为Java类型中的 java.lang.Long类型,并不是我简单认为的 Integer ,还会报一个错误:

java.lang.IllegalArgumentException: Can not set java.lang.Integer field com.jacob.pojo.User.id to java.lang.Long
    at java.base/jdk.internal.reflect.UnsafeFieldAccessorImpl.throwSetIllegalArgumentException(UnsafeFieldAccessorImpl.java:167)
    at java.base/jdk.internal.reflect.UnsafeFieldAccessorImpl.throwSetIllegalArgumentException(UnsafeFieldAccessorImpl.java:171)
    at java.base/jdk.internal.reflect.UnsafeObjectFieldAccessorImpl.set(UnsafeObjectFieldAccessorImpl.java:81)
    at java.base/java.lang.reflect.Field.set(Field.java:780)

就是说Bigint的字段不能set进Integer类型的属性中.

如果使用原生的JDBC来封装数据,在这个

;