我的编程空间,编程开发者的网络收藏夹
学习永远不晚

使用Mybatis更新时候只更新变更部分的方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

使用Mybatis更新时候只更新变更部分的方法

Mybatis更新时候只更新变更部分

在更新数据库的某条记录的时候,通过我们只需要更新我们设置的字段就可以了,但是如果基于ORM映射更新,当参数传入的为一个Bean的时候,这个时候会将Bean的全部字段都更新一次。

有一个场景的如在登陆时候,如果用户登陆成功以后只想更新用户登陆的ip跟时间,对于这一类场景可以用mybatis的SqlProvider方法来只更新我们设置的字段,

具体可以参考以下代码

Dao:

package org.**.dao; 
import java.sql.Timestamp; 
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Result;
import org.apache.ibatis.annotations.Results;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.UpdateProvider;
import org.**.beans.User;
import org.**.sql.provider.UserSqlProvider;
import org.springframework.stereotype.Repository;
 
@Repository("userDao")
public interface UserDao {
    
    @Select("select * from j_user where username=#{username} and password=#{password}")
    @Results({
        @Result(id=true, property="userId", column="user_id", javaType=Integer.class),
        @Result(property="username", column="username", javaType=String.class),
        @Result(property="password", column="password", javaType=String.class),
        @Result(property="email", column="email", javaType=String.class),
        @Result(property="registerTime", column="register_time", javaType=Timestamp.class),
        @Result(property="registerIp", column="register_ip", javaType=String.class),
        @Result(property="lastLoginTime", column="last_login_time", javaType=Timestamp.class),
        @Result(property="lastLoginIp", column="last_login_ip", javaType=String.class),
        @Result(property="loginCount", column="login_count", javaType=Integer.class),
        @Result(property="errorTime", column="error_time", javaType=Timestamp.class),
        @Result(property="errorCount", column="error_count", javaType=Integer.class),
        @Result(property="errorIp", column="error_ip", javaType=String.class)
    })
    public User getUserByUsernameAndPassword(@Param("username") String username, @Param("password") String password);
    
    @UpdateProvider(type = UserSqlProvider.class, method = "update")
    public int updateLoginInfo(User user);
}

SqlProvider:

package org.**.sql.provider; 
import org.apache.commons.lang3.StringUtils;
import org.apache.ibatis.jdbc.SQL;
import org.**.beans.User; 
 
public class UserSqlProvider {    
    public String update(final User user) {
        return new SQL(){
            {
                UPDATE("jo_user");
                
                if (StringUtils.isNotBlank(user.getUsername())) {
                    SET("username = #{username}");
                }
                
                if (StringUtils.isNotBlank(user.getEmail())) {
                    SET("email = #{email}");
                }
                
                if (StringUtils.isNotBlank(user.getPassword())) {
                    SET("password = #{password}");
                }
                
                if (user.getRegisterTime() != null) {
                    SET("register_time = #{registerTime}");
                }
                
                if (StringUtils.isNotBlank(user.getRegisterIp())) {
                    SET("register_ip = #{registerIp}");
                }
                
                if (user.getLastLoginTime() != null ) {
                    SET("last_login_time = #{lastLoginTime}");
                }
                
                if (StringUtils.isNotBlank(user.getLastLoginIp())) {
                    SET("last_login_ip = #{lastLoginIp}");
                }
                
                if (StringUtils.isNotBlank(user.getLoginCount().toString())) {
                    SET("login_count = #{loginCount}");
                }
                
                if (StringUtils.isNotBlank(user.getResetKey())) {
                    SET("reset_key = #{resetKey}");
                }
                
                if (StringUtils.isNotBlank(user.getResetPwd())) {
                    SET("reset_pwd = #{resetPwd}");
                }
                
                if (user.getErrorTime() != null) {
                    SET("error_time = #{errorTime}");
                }
                
                if (StringUtils.isNotBlank(user.getErrorCount().toString())) {
                    SET("error_count = #{errorCount}");
                }
                
                if (StringUtils.isNotBlank(user.getErrorIp())) {
                    SET("error_ip = #{errorIp}");
                }
                
                if (StringUtils.isNotBlank(user.getActivationCode())) {
                    SET("activation_code = #{activationCode}");
                }
                
                WHERE("user_id = #{userId}");
            }
        }.toString();
    } 
}

Mybatis update更新字段的使用

多个mapper方法,更新单字段

说实话不太推荐,因为如果有10个字段要更新,难道写10个方法。

但是实际中很多人都这么写。

通用mapper方法,java代码控制字段

特点是一个mapper方法包含所有字段,不为空的就update。

但是需要控制入参,一般有2中方式:

new 一个对象然后set id和要改的字段

如果字段多比较费劲,需要一个一个set。

查询出对象,然后set要改的字段

这2种方式差不多,就是代码看起来不一样。

特别注意,定位字段不要加if

要更新的字段加if没有什么问题

但是定位条件不要加if,因为万一忘记传递了,变成没有where条件,那么条数不可控了。搞不好把全表更新了,可就万劫不复了。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

使用Mybatis更新时候只更新变更部分的方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql多表join时候update更新数据的方法

如果item表的name字段为''就用resource_library 表的resource_name字段前面加上字符串Review更新它,他们的关联关系在表resource_review_link中。
2022-11-21

使用MyBatis进行简单的更新与查询方式

这篇文章主要介绍了使用MyBatis进行简单的更新与查询方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

aspnet core使用websocket实时更新商品信息的方法

ASP.NETCore中使用WebSocket实时更新商品信息WebSocket是一种双向实时通信协议,非常适合在电子商务网站中更新商品信息。ASP.NETCore提供了WebSocket框架,用于创建WebSocket服务器并处理连接。通过推送消息,服务器可以主动向客户端发送更新,无需客户端请求。最佳实践包括考虑并发性、使用高效数据格式、实现重连机制,以及实施安全措施。通过使用WebSocket,企业可以创建实时商品信息更新系统,增强用户体验并确保客户了解最新信息。
aspnet core使用websocket实时更新商品信息的方法
2024-04-02

更新IP代理服务器的使用方法

这篇文章主要介绍了更新IP代理服务器的使用方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一些做游戏代理的朋友。需要在不同地区切换ip,玩游戏的时候也需要显示这些地方的ip
2023-06-15

使用yum更新时不升级Linux内核的方法介绍

本篇内容主要讲解“使用yum更新时不升级Linux内核的方法介绍”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“使用yum更新时不升级Linux内核的方法介绍”吧!RedHat/CentOS/Fe
2023-06-10

SQL 数据的更新(UPDATE 语句的使用方法)

目录一、UPDATE 语句的基本语法二、指定条件的 UPDATE 语句(搜索型 UPDATE)三、使用 NULL 进行更新四、多列更新请参阅学习重点使用 UPDATE 语句可以更改(更新)表中的数据。更新部分数据行时可以使用 WHERE 来指定更新对象的条件。
SQL 数据的更新(UPDATE 语句的使用方法)
2017-08-23

Android在线更新SDK的方法(使用国内镜像)

本文讲述了Android使用国内镜像在线更新SDK的方法。分享给大家供大家参考,具体如下: 什么是Android SDK: SDK:(software development kit)软件开发工具包。被软件开发工程师用于为特定的软件包、软件
2022-06-06

win10更新后网络使用不了的解决方法

这篇文章主要介绍了win10更新后网络使用不了的解决方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体方法如下:1、首先我们使用快捷键“win+I”打开【设置】界面,在设
2023-06-10

dedecms编辑修改文章后使发布时间更新为最新时间的解决方法

在使用dedecms程序的时候,我们经常会编辑会修改文章,通常发布之后时间为最新的当前时间,但是dedecms默认的时间还是以前的发布时间,我们如何来实现编辑文章后使发布时间自动变为当前最新时间呢?而且文章会自动更新到最编程客栈前面! 这个
2022-06-12

小程序js文件改变参数并在视图上及时更新的方法

这篇文章主要介绍了小程序js文件改变参数并在视图上及时更新的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇小程序js文件改变参数并在视图上及时更新的方法文章都会有所收获,下面我们一起来看看吧。一、简单参数X
2023-06-26

Android App实现应用内部自动更新的最基本方法示例

这只是初步的实现,并没有加入自动编译等功能。需要手动更改更新的xml文件和最新的apk。 共涉及到四个文件! 一、客户端 AndroidUpdateTestActivity:程序首页 main.xml:首页布局 Update:更新类
2022-06-06

ubuntu中snap包安装、更新删除与使用的方法是什么

这篇“ubuntu中snap包安装、更新删除与使用的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“ubuntu中s
2023-07-04

PHPCMS使用date函数实现自动更新页脚年月的方法

可能大家光看标题不知道是什么意思,其实我也不知道得怎么下标题比较好,就是那个大部分网站都会用到的在底部的版权信息,例如复制代码代码如下:Copyright 2007-2015 &编程客栈copy; jb51.net® Inc. Al
2022-06-12

vue的异步数据更新机制与$nextTick使用方法是什么

这篇文章主要讲解了“vue的异步数据更新机制与$nextTick使用方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue的异步数据更新机制与$nextTick使用方法是什么”吧!v
2023-07-05

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录