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

今天说一下本身在项目中遇到的问题,而后总结一下Integer引用类型和int值类型mybatis

关于默认值

  1. Integer默认为null
  2. int默认为0

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

大叔认识,这样设计有助于咱们区分这个字段是否被设置过,或者说是否被set过,而对于Integer来讲,若是没有被set过,它必定是null(固然你把它强制改成null除外),而对于int来讲,你没法区别0和默认值,由于它默认就是0,我以为这是最重要的一点。app

  1. 能够区分属性是否被设置过值

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的数据,这不是咱们所但愿的!code

相关文章
相关标签/搜索