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,批量,修改
0
投稿

猜你喜欢

  • java整合SSM框架的图文教程

    2023-03-11 01:06:30
  • JAVA通过HttpClient发送HTTP请求的方法示例

    2023-08-24 18:45:47
  • Java中两种基本的输入方式小结

    2023-02-06 18:37:24
  • 实例讲解JAVA设计模式之备忘录模式

    2023-08-29 16:31:19
  • Android PickerView实现三级联动效果

    2023-02-25 15:05:47
  • .NET WinForm实现在listview中添加progressbar的方法

    2021-10-08 20:23:54
  • Spring Cloud Gateway全局通用异常处理的实现

    2022-05-08 08:03:10
  • Android中使用ScrollView指定view的顶部悬停效果

    2021-10-02 13:32:38
  • SpringCloud迈向云原生的步骤

    2023-08-21 22:59:46
  • Android Handler使用案例详解

    2021-08-17 06:46:32
  • C# using的本质及使用详解

    2022-10-10 06:11:23
  • SpringBoot切面拦截@PathVariable参数及抛出异常的全局处理方式

    2023-05-27 13:59:52
  • Android编程实现读取本地SD卡图片的方法

    2023-01-10 01:32:30
  • Android最简单的限制输入方法(只包含数字、字母和符号)

    2022-01-22 00:15:45
  • Springboot实现图片上传功能的示例代码

    2022-08-05 22:46:44
  • C#中Span相关的性能优化建议

    2021-07-05 15:42:26
  • 浅析C#中文件路径的操作

    2023-11-09 16:24:30
  • Spring Data Jpa的四种查询方式详解

    2021-10-10 10:35:26
  • java清除u盘内存卡里的垃圾文件示例

    2023-05-12 06:41:38
  • java判断字符串是否有逗号的方法

    2021-11-03 08:01:23
  • asp之家 软件编程 m.aspxhome.com