码迷,mamicode.com
首页 > 其他好文 > 详细

Integer和int踩过的坑

时间:2019-07-24 22:33:19      阅读:88      评论:0      收藏:0      [点我收藏+]

标签:区别   数字   测试   com   null   一个   alt   数据库表   int   

在做SSM项目时发现一个有趣的bug,在这里记录一下。

数据库表如下:

技术图片

实体类:grade字段初始设定为int类型

技术图片

在用mybatis对第三条数据进行修改时,希望赋值的更改,未赋值的不更改,测试运行

技术图片

技术图片

 

修改后发现数据库中的grade字段变成了0,这不是我想要的,(按照正常需求应该是原来的数字5)

技术图片

 

查看了一下日志,发现了猫腻:

技术图片

 int 类型,在默认情况下不赋值为0,执行到mybatis的更新语句时,被当做数字0,而非null,

仔细想想Integer和int 的区别,integer的默认值为null,即Integer可以区分出未赋值和值为0的区别,int则无法表达出未赋值的情况,

我又把之前实体类中的grade 类型改为了Integer成功实现了自己想要的。

总结:在实体类中尽量使用Integer修饰,Integer可以区分出未赋值和值为0的区别,我们大部分做判断都是以“”null“”去判断的,特在此做个笔记。

Integer和int踩过的坑

标签:区别   数字   测试   com   null   一个   alt   数据库表   int   

原文地址:https://www.cnblogs.com/ly-520/p/11241080.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!