SpringBoot攻略十一、mybatisplus自定义ISqlInjector,添加updateAllColumnById通用方法

本文介绍了如何在SpringBoot应用中使用MybatisPlus进行集成,并自定义ISqlInjector实现通用的updateAllColumnById方法。通过创建GeneralMybatisPlusSqlInjector、UpdateAllColumnById类,以及枚举类GeneralMybatisPlusSqlMethod,开发者可以扩展MybatisPlus的功能。同时,配置文件加载自定义sql注入器,并定义基础Mapper和Service,使得所有子类能继承这些功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考【SpringBoot攻略七、集成mybatisplus实战】,做如下修改:

1、自定义sql注入器GeneralMybatisPlusSqlInjector

package com.javasgj.springboot.mybatisplus.config;

import java.util.List;

import com.baomidou.mybatisplus.core.injector.AbstractMethod;
import com.baomidou.mybatisplus.core.injector.DefaultSqlInjector;

/**
 * 自定义sql注入器,增加通用方法
 */
public class GeneralMybatisPlusSqlInjector extends DefaultSqlInjector {

	@Override
	public List<AbstractMethod> getMethodList() {
		
		List<AbstractMethod> methodList = super.getMethodList();
		
		// 根据id更新所有数据
		methodList.add(new UpdateAllColumnById());
		return methodList;
	}
}

2、方法对应的实现类UpdateAllColumnById

package com.javasgj.springboot.mybatisplus.config;

import static java.util.stream.Collectors.joining;

import org.apache.ibatis.mapping.MappedStatement;
import org.apache.ibatis.mapping.SqlSource;

import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.core.injector.AbstractMethod;
import com.baomidou.mybatisplus.core.metadata.TableFieldInfo;
import com.baomidou.mybatisplus.core.metadata.TableInfo;
import com.baomidou.mybatisplus.core.toolkit.Constants;
import com.baomidou.mybatisplus.core.toolkit.StringPool;
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
import com.baomidou.mybatisplus.core.toolkit.sql.SqlScriptUtils;

/**
 * 根据id更新所有数据
 */
public class UpdateAllColumnById extends AbstractMethod {

    @Override
    public MappedStatement injectMappedStatement(Class<?> mapperClass, Class<?> modelClass, TableInfo tableInfo) {
    	
    	GeneralMybatisPlusSqlMethod sqlMethod = GeneralMybatisPlusSqlMethod.UPDATE_ALL_COLUMN_BY_ID;
        String sql = String.format(sqlMethod.getSql(), tableInfo.getTableName(),
            sqlSet(false, false, tableInfo, Constants.ENTITY_SPOT),
            tableInfo.getKeyColumn(), Constants.ENTITY_SPOT + tableInfo.getKeyProperty(),
            new StringBuilder("<if test=\"et instanceof java.util.Map\">")
 
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值