mybatisPlus底层的新增方法是一条一条的新增的,今天自定义批量新增方法。
创建自定义数据方法注入类
/** * @Description: EasySqlInjector 自定义数据方法注入 * @Author WangYejian * @Date: 2020/11/4 14:34 */ public class EasySqlInjector extends DefaultSqlInjector { @Override public List<AbstractMethod> getMethodList(Class<?> mapperClass) { //防止父类方法不可用 List<AbstractMethod> methods= super.getMethodList(mapperClass); methods.add(new InsertBatchSomeColumn()); return methods; } }
在mybatisplus配置文件MybatisPlusConfig加入自定义
@Bean public EasySqlInjector easySqlInjector() { return new EasySqlInjector(); }
创建EasyBaseMapper 扩展通用 Mapper
package com.cgmcomm.mallplus.basic.mapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import java.util.Collection; /** * @Description: EasyBaseMapper 扩展通用 Mapper,支持数据批量插入 * @Author WangYejian * @Date: 2020/10/15 18:57 */ public interface EasyBaseMapper<T> extends BaseMapper<T> { /** * 批量插入 仅适用于mysql * * @param entityList 实体列表 * @return 影响行数 */ Integer insertBatchSomeColumn(Collection<T> entityList); }
** * 定义业务mapper接口,继承刚刚扩展的EasyBaseMapper * * @author 天开易想 */ @Mapper public interface TestMapper extends EasyBaseMapper<Test> { } /** * 业务实现类接口,即可引用 */ @Service public class TestServiceImpl extends ServiceImpl<TestMapper, Test> implements TestService { @Override public Integer testBatch(Collection<Test> testList) { return baseMapper.insertBatchSomeColumn(testList); }
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论(0)