MybatisPlus使用LambdaQueryWrapper更新时 int默认值问题

问题:

java 复制代码
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语句扫描加载并执行

powershell 复制代码
 ==>  Preparing: UPDATE user SET status=?, balance=? WHERE (username = ?)
 ==> Parameters: 0(Integer), 1000(Integer), Jack(String)

解决方案

将User实体类中的int属性改为Integer

java 复制代码
//    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
相关推荐
Wonderful U几秒前
Python+Django实战|校园二手闲置交易平台:从实名认证到交易闭环的完整校园电商解决方案
开发语言·python·django
listhi5203 分钟前
基于雅克比迭代法的方腔流动 MATLAB 实现
开发语言·matlab
小白学大数据4 分钟前
全站链接深度爬取:Python GUI 事件绑定 + 运行时动态过滤实现思路
开发语言·爬虫·python
郝学胜-神的一滴8 分钟前
Qt 高级开发 022:栅格布局深度实战
开发语言·c++·qt·软件构建·用户界面
codeejun14 分钟前
每日一 Go-72、分布式事务 & 一致性:本地消息表、事务消息、SAGA、TCC怎么选?
开发语言·分布式·golang
土狗TuGou14 分钟前
SQL进阶笔记 · 第1篇:存储引擎
java·数据库·笔记·后端·sql·mysql
sycmancia15 分钟前
Qt——程序中的配置文件
开发语言·qt
赶在日落之前18 分钟前
使用conda-pack打包完整 Python 环境 + 依赖包,传到无网机器解压即用
开发语言·人工智能·python
雨落在了我的手上20 分钟前
Java数据结构(一):初识集合框架
java·开发语言
程序大视界21 分钟前
【C++ 从基础到项目实战】C++(三):函数进阶——重载、回调、递归与默认参数
开发语言·c++·cpp