Java Mybatis批量修改封装详解
作者:头发多的码农 时间:2021-12-29 22:41:52
重点重点重点,不然会报错
连接数据库url后面加个参数
allowMultiQueries=true
用习惯了 insertList 怎么能没有 updateList呢
就两个类 直接上代码
package com.lancabbage.gorgeous.utils.mybatis;
import org.apache.ibatis.mapping.MappedStatement;
import tk.mybatis.mapper.entity.EntityColumn;
import tk.mybatis.mapper.mapperhelper.EntityHelper;
import tk.mybatis.mapper.mapperhelper.MapperHelper;
import tk.mybatis.mapper.mapperhelper.MapperTemplate;
import tk.mybatis.mapper.mapperhelper.SqlHelper;
import java.util.Set;
import static tk.mybatis.mapper.mapperhelper.SqlHelper.whereVersion;
/**
* ListUpdateProvider实现类,批量修改方法实现类
*
* @author lanyanhua
*/
public class ListUpdateProvider extends MapperTemplate {
public ListUpdateProvider(Class<?> mapperClass, MapperHelper mapperHelper) {
super(mapperClass, mapperHelper);
}
// /**
// * 通过主键更新全部字段
// *
// * @param ms
// */
// public String updateByPrimaryKey(MappedStatement ms) {
// Class<?> entityClass = getEntityClass(ms);
// StringBuilder sql = new StringBuilder();
// sql.append(SqlHelper.updateTable(entityClass, tableName(entityClass)));
// sql.append(SqlHelper.updateSetColumns(entityClass, null, false, false));
// sql.append(SqlHelper.wherePKColumns(entityClass, true));
// return sql.toString();
// }
/**
* 通过主键更新不为null的字段
*
* @param ms
* @return
*/
public String updateByPrimaryKeySelectiveList(MappedStatement ms) {
Class<?> entityClass = getEntityClass(ms);
StringBuilder sql = new StringBuilder();
sql.append("<foreach collection=\"list\" item=\"record\" >");
//set
sql.append(SqlHelper.updateTable(entityClass, tableName(entityClass)));
sql.append(SqlHelper.updateSetColumns(entityClass, "record", true, isNotEmpty()));
//where
sql.append("<where>");
Set<EntityColumn> columnSet = EntityHelper.getPKColumns(entityClass);
//当某个列有主键策略时,不需要考虑他的属性是否为空,因为如果为空,一定会根据主键策略给他生成一个值
for (EntityColumn column : columnSet) {
sql.append(" AND ").append(column.getColumnEqualsHolder("record"));
}
sql.append(whereVersion(entityClass));
sql.append("</where>");
sql.append(" ;\n");
sql.append("</foreach>");
return sql.toString();
}
}
package com.lancabbage.gorgeous.utils.mybatis;
import org.apache.ibatis.annotations.UpdateProvider;
import tk.mybatis.mapper.annotation.RegisterMapper;
import java.util.List;
/**
* 通用Mapper接口,更新
*
* @param <T> 不能为空
* @author lanyanhua
*/
@RegisterMapper
public interface ListUpdateByPrimaryKeySelectiveMapper<T> {
/**
* 根据主键更新属性不为null的值
*
* @param record
* @return
*/
@UpdateProvider(type = ListUpdateProvider.class, method = "dynamicSQL")
int updateByPrimaryKeySelectiveList(List<T> record);
}
我是使用的是Tk.mybatis。代码是复制的原来的updateByPrimaryKeySelective的代码进行的微调
保证最终的结构类似这种就ok
<foreach collection="list" item="record" separator=";">
UPDATE project
<set>id = id,
<if test="record.name != null">name = #{record.name},</if>
<if test="record.remotePath != null">remote_path = #{record.remotePath},</if>
<if test="record.createTime != null">create_time = #{record.createTime},</if>
<if test="record.isShow != null">is_show = #{record.isShow},</if>
<if test="record.displayOrder != null">display_order = #{record.displayOrder},</if>
</set>
<where>AND id = #{record.id}</where>
</foreach>
使用 就和其他的一样 在你的Mapper类上继承这个类ListUpdateByPrimaryKeySelectiveMapper就好了
public interface BaseMapper<T> extends Mapper<T>, MySqlMapper<T>, ListUpdateByPrimaryKeySelectiveMapper<T> {
}
来源:https://blog.csdn.net/lanyanhua/article/details/121034603
标签:Java,Mybatis,批量,修改
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
c#操作ftp类分享
2023-02-27 12:50:17
winform绑定快捷键的方法
2023-12-10 22:16:04
java 中的instanceof用法详解及instanceof是什么意思(推荐)
2023-06-07 13:52:27
详解SpringBoot通用配置文件(不定时更新)
2022-12-01 09:07:04
java.net.SocketException: Connection reset 解决方法
2023-06-17 01:28:43
![](https://img.aspxhome.com/file/2023/6/57416_0s.png)
java链式创建json对象的实现
2023-11-12 12:36:51
Java判断两个日期相差天数的方法
2021-11-29 05:55:07
浅谈java中的重载和重写的区别
2023-03-31 04:45:57
![](https://img.aspxhome.com/file/2023/6/75516_0s.png)
Java案例之随机验证码功能实现实例
2022-05-24 13:28:16
![](https://img.aspxhome.com/file/2023/8/75498_0s.png)
java多线程Synchronized实现可见性原理解析
2021-08-26 02:10:02
![](https://img.aspxhome.com/file/2023/6/71216_0s.jpg)
Spring Boot 2.7.6整合redis与低版本的区别
2023-11-11 19:44:56
![](https://img.aspxhome.com/file/2023/7/59697_0s.png)
HttpServletRequest对象常用功能_动力节点Java学院整理
2022-01-05 10:37:08
![](https://img.aspxhome.com/file/2023/1/74931_0s.png)
c#窗体传值用法实例详解
2022-04-04 03:44:15
Java 从互联网上爬邮箱代码示例
2022-02-27 16:40:57
SpringCloudAlibaba整合Feign实现远程HTTP调用的简单示例
2023-11-19 16:16:05
![](https://img.aspxhome.com/file/2023/9/59669_0s.png)
Java 容器类源码详解 Set
2022-03-21 18:08:40
Java中StringUtils与CollectionUtils和ObjectUtil概念讲解
2023-11-29 07:45:38
![](https://img.aspxhome.com/file/2023/4/59004_0s.png)
java 中HashCode重复的可能性
2021-09-13 17:38:05
Android手动检查并申请权限方法
2023-08-04 23:14:17
SpringMVC如何接收参数各种场景
2022-01-23 22:56:24