内容简介:今天说一下自己在项目中遇到的问题,然后总结一下Integer引用类型和int值类型大叔认识,这样设计有助于我们区分这个字段是否被设置过,或者说是否被set过,而对于Integer来说,如果没有被set过,它一定是null(当然你把它强制改为null除外),而对于int来说,你无法区别0和默认值,因为它默认就是0,我觉得这是最重要的一点。QueryWrapper是一个mybatis里的查询构造器,你可以为实体属性赋值,然后以它为一个依据,去查询与它匹配的结果集,当你没有为属性赋值时,它是null,(而对于i
今天说一下自己在项目中遇到的问题,然后总结一下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的数据,这不是我们所希望的!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Spark技术内幕
张安站 / 机械工业出版社 / 2015-9-1
Spark是不断壮大的大数据分析解决方案家族中备受关注的新增成员。它不仅为分布式数据集的处理提供一个有效框架,而且以高效的方式处理分布式数据集。它支持实时处理、流处理和批处理,提供了AllinOne的统一解决方案,使得Spark极具竞争力。 本书以源码为基础,深入分析Spark内核的设计理念和架构实现,系统讲解各个核心模块的实现,为性能调优、二次开发和系统运维提供理论支持;本文最后以项目实战......一起来看看 《Spark技术内幕》 这本书的介绍吧!
随机密码生成器
多种字符组合密码
HTML 编码/解码
HTML 编码/解码