问题:
User user = new User();
user.setBalance(1000);
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("username","Jack");
userMapper.update(user, queryWrapper);
通过用户名,更新金额,使用queryWrapper,出现了多更新其他字段的问题。
原因
User实体类中,存在int属性,int属性具有默认值0,在执行userMapper.update(user, queryWrapper);
语句时,user中除了我们set的Balance外,还存在一个int字段status的默认值是0,也会被update语句扫描加载并执行
==> Preparing: UPDATE user SET status=?, balance=? WHERE (username = ?)
==> Parameters: 0(Integer), 1000(Integer), Jack(String)
解决方案
将User实体类中的int属性改为Integer
// private int status;
// private int balance;
private Integer status;
private Integer balance;
问题分析
int:
- int是32位 有符号的以二进制补码表示的整数
- 最小值是-2147483648(-2^31)
- 最大值是 2147483647(2^31-1)
- 一般的整形变量默认为int类型
- 默认值是0
Integer
Integer类包含四种常量:
- MAX_VALUE:值为2^31-1的常量,表示int类型能够表示的最大值
- MIN_VALUE:值为-2^31的常量,表示int类型能够表示的最小值
- SIZE:用来以二进制补码形式表示int值的比特位数
- TYPE:表示基本类型int的class实例
总结
- int类型是基本数据类型,Integer是引用数据类型
- Integer是int类型的包装类,int的初始值是0,Integer的初始值是null