springboot~Integer和int如何选择,Integer的意义何在

本文探讨了在SpringBoot项目中,Integer引用类型与int值类型的区别。主要集中在Integer的默认值为null能帮助区分字段是否被设置,而在QueryWrapper中,Integer避免了0作为默认值带来的查询困扰。通过实例说明,强调理解并正确使用这两种类型的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天说一下自己在项目中遇到的问题,然后总结一下Integer引用类型和int值类型
关于默认值

Integer默认为null
int默认为0

为什么把数据实体设计成Integer或者不是int

大叔认识,这样设计有助于我们区分这个字段是否被设置过,或者说是否被set过,而对于Integer来说,如果没有被set过,它一定是null(当然你把它强制改为null除外),而对于int来说,你无法区别0和默认值,因为它默认就是0,我觉得这是最重要的一点。

可以区分属性是否被设置过值

QueryWrapper里更加适合Integer

QueryWrapper是一个mybatis里的查询构造器,你可以为实体属性赋值,然后以它为一个依据,去查询与它匹配的结果集,当你没有为属性赋值时,它是null,(而对于int来说,它是0,0往往是有意义的,在QueryWrapper里,你无法忽略int的属性,这是十分尴尬的)。
例子,两个实体

public class UserInfo extends BaseEntity {

  private String name;
  private String email;
  private Integer age;
}

public class UserInfo extends BaseEntity {

  private String name;
  private String email;
  private int age;
}

在QueryWrapper里进行条件的构造

   UserInfo query = new UserInfo();
    query.setName("lind");
    query.setEmail("bfyxzls@sina.com"); //当没有设置Age属性时,它是null,在QueryWrapper里将被忽略,即查询所有Age
    UserInfo dbUser = userInfoMapper.selectOne(new QueryWrapper<>(query));
    System.out.println(dbUser);
    Assert.assertEquals("lind", dbUser.getName());
上面的代码中,如果把Age改成int类型,那它只能查询出Age=0的数据,这不是我们所希望的!

只要一步一个脚印,水滴石穿,吃透、搞懂、拿捏住是完全没有问题的!看到这里的都是妥妥的铁粉无疑了,底下是微信,找到的可是有大把源码,学习路线思维导图啥的,多的我就不透露,539413949看大家自己的积极性了啊,热爱所热爱的,学习伴随终生

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值