Java Mybatis批量修改封装详解

网友投稿 259 2022-11-26

Java Mybatis批量修改封装详解

重点重点重点,不然会报错

连接数据库url后面加个参数

allowMultiQueries=true

用习惯了 insertList 怎么能没有 updateList呢

就两个类 直接上代码

package com.lancabbage.gorgeous.utils.mybatis;

import org.apache.ibatis.mapping.MappedStatement;

import tk.mybatis.mapper.entity.EntityColumn;

imyAKLxport 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("");

//set

sql.append(SqlHelper.updateTable(entityClass, tableName(entityClass)));

sql.append(SqlHelper.updateSetColumns(entityClass, "record", true, isNotEmpty()));

http:////where

sql.append("");

Set columnSet = EntityHelper.getPKColumns(entityClass);

//当某个列有主键策略时,不需要考虑他的属性是否为空,因为如果为空,一定会根据主键策略给他生成一个值

for (EntityColumn column : columnSet) {

sql.append(" AND ").append(column.getColumnEqualsHolder("record"));

}

sql.append(whereVersion(entityClass));

sql.append("");

sql.append(" ;\n");

sql.append("");

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 不能为空

* @author lanyanhua

*/

@RegisterMapper

public interface ListUpdateByPrimaryKeySelectiveMapper {

/**

* 根据主键更新属性不为null的值

*

* @param record

* @return

*/

@UpdateProvider(type = ListUpdateProvider.class, method = "dynamicSQL")

intyAKLx updateByPrimaryKeySelectiveList(List record);

}

我是使用的是Tk.mybatis。代码是复制的原来的updateByPrimaryKeySelective的代码进行的微调

保证最终的结构类似这种就ok

UPDATE project

id = id,

name = #{record.name},

remote_path = #{record.remotePath},

create_time = #{record.createTime},

is_show = #{record.isShow},

display_order = #{record.displayOrder},

AND id = #{record.id}

使用 就和其他的一样 在你的Mapper类上继承这个类ListUyAKLxpdateByPrimaryKeySelectiveMapper就好了

public interface BaseMapper extends Mapper, mysqlMapper, ListUpdateByPrimaryKeySelectiveMapper {

}

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注我们的更多内容!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:配电自动化终端dtu的功能都有哪些
下一篇:27 python 定义 列表 序列的基本操作 序列的分片
相关文章

 发表评论

暂时没有评论,来抢沙发吧~