请问hibernate里实体类用int和Integer区别?
1听说在hibernate里int类型的话,是会被自动转成Integer的?那如果是这样的话,我用int也行喽?但是如果返回的数据库字段值为null,不知道int类型还能...
1听说在hibernate里int类型的话,是会被自动转成Integer的?
那如果是这样的话,我用int也行喽?
但是如果返回的数据库字段值为null,不知道int类型还能接收到吗,会不会报错?
==========================================================
2如果不用框架的话,比如用jdbc直接写,那实体类里属性用int类型,然后我的实体类没有实现序列化接口,
保存到数据库会不会报错,有没有提示我没实现Serializable接口什么之类的呢?
我知道Integer默认是实现Serializable,int类型好像没有吧? 展开
那如果是这样的话,我用int也行喽?
但是如果返回的数据库字段值为null,不知道int类型还能接收到吗,会不会报错?
==========================================================
2如果不用框架的话,比如用jdbc直接写,那实体类里属性用int类型,然后我的实体类没有实现序列化接口,
保存到数据库会不会报错,有没有提示我没实现Serializable接口什么之类的呢?
我知道Integer默认是实现Serializable,int类型好像没有吧? 展开
4个回答
展开全部
1、返回数据库字段值是null的话,int类型会报错。int是基本数据类型,其声明的是变量,而null则是对象。所以hibernate实体建议用integer;
2、不会报错吧,通过jdbc将实体存储到数据库的操作不是通过sql语句么,基本数据类型可以直接存储的,而对象才需要序列化存储。
2、不会报错吧,通过jdbc将实体存储到数据库的操作不是通过sql语句么,基本数据类型可以直接存储的,而对象才需要序列化存储。
追问
言之有理,那请问为什么jdbc既然实体类不序列化也不影响存储,那一般都给实体类实现序列化呢?有什么好处吗?
追答
实体类实现序列化的意义在于网络传输,序列化可以把对象转换为字节流,反序列化可以将对应的流解析为对象,满足安全性和一致性需求。
展开全部
如果数据库返回的为null则会报错,因为int不能为null。
你用JDBC保存的是执行SQL语句,只是把实体类属性的值赋给了SQL语句。
关于序列化建议看一下这篇文章http://blog.csdn.net/yakihappy/article/details/3979373
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
第一个问题是会报错的
第二个问题不会报错 直接会以Integer类型存入数据库
第二个问题不会报错 直接会以Integer类型存入数据库
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
int类型对于空会保存默认值0,integer会报空指针异常,亲测
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询