美文网首页
为什么数据库表的int类型字段映射到实体类中要使用Integer

为什么数据库表的int类型字段映射到实体类中要使用Integer

作者: Alex_1799 | 来源:发表于2018-04-17 17:28 被阅读0次

    如果返回字段值为null,int类型会报错,Integer不会报错。因为int类型声明的是变量,而null是对象所以会报错。Integer是包装类,包装类符合对象的特征并提供了一些必要的属性和方法。

    int类型的默认值为0,Integer类型的默认值为null。

      我们知道,一些框架并没有要求(实体类 )属性必须是基本数据类型或者是包装类,但是我们把属性声明为基本数据类型( primitive types directly)或者包装类 ( wrapping classes for primitives)对我们代码的编写有着深远的影响。


    1,使用基本数据类型的好处

    a),使用基本数据类型意味着你所定义的属性不允许为空,这样你在获取该属性的时候就不可能会得到一个null值。

    b),int在java中占32/64 bits,而Integer占了16个字节,所以使用Integer在性能方面要比int差一些。

    2,使用包装类的好处

    a),当我们不想给这个属性设置任何值的时候,我们可以给它一个null值(前提是数据库的字段允许插入NULL)。

    b),我们可以在pojo类中使用验证注解对属性的值做校验(例如: javax.validation.constraints.NotNull)

    4,两者在实际开发中的比较

    a),如果你的数据库字段是允许为空的,使用包装类。如果不允许为空,使用包装的时候,如果你往数据库插入null值,此时就会抛出异常。然后你就可以对异常进行捕获并处理。

    b),使用基本数据类型的时候,如果字段是NULL,那么JDBC会返回0,但是这里会有一个问题。有可能0在你的业务逻辑代表着特定含义,这时候就可能出现一些意想不到的后果。

    总结:在项目中去使用包装类型而不是基本数据类型,这样可以使你编写代码更简单,除非有人给你一个更好的理由去使用基本数据类型或者你的上头要求一定要使用基本数据类型。

    相关文章

      网友评论

          本文标题:为什么数据库表的int类型字段映射到实体类中要使用Integer

          本文链接:https://www.haomeiwen.com/subject/wgsekftx.html