MybatisPlus 之 PaginationInterceptor 扩展配置bean

package com.dcits.branch.cloud.tran.configuration;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.core.parser.ISqlParser;
import com.baomidou.mybatisplus.extension.parsers.DynamicTableNameParser;
import com.baomidou.mybatisplus.extension.parsers.ITableNameHandler;
import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
import com.dcits.branch.cloud.components.context.ContextManager;
import com.dcits.branch.cloud.components.context.ContextManagerImpl;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.reflection.wrapper.BeanWrapper;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * <pre>
 * 类功能:MybatisPlus 扩展配置bean
 * oracle 数据源切换 mysql,报错 MySQLSyntaxErrorException: Every derived table must have its own alias
 * 设置注意 paginationInterceptor.setDialectType(DbType.MYSQL.getDb());
 * </pre>
 *
 * @author dcits.xupengfei 2019/3/9
 * @desc: MybatisPlus 扩展配置bean
 * @modify dcits.xupengfei 2020/3/9 初始创建
 */
@MapperScan({"com.dcits.branch.cloud.tran.order.dao.mapper", "com.dcits.branch.cloud.tran.prdbusi.dao.mapper"})
@Configuration
@Slf4j
public class MybatisPlusConfig {

    private final static String MPTBL_CM_TRAN_JOURNAL = "CM_TRAN_JOURNAL";

    @Bean
    public PaginationInterceptor paginationInterceptor() {
        PaginationInterceptor paginationInterceptor = new PaginationInterceptor();

        List<ISqlParser> sqlParserList = new ArrayList<>();
        // --- 动态表名映射
        DynamicTableNameParser dynamicTableNameParser = new DynamicTableNameParser();
        ITableNameHandler myTableNameHandler = (metaObject, sql, tableName) -> {
            Object objectWrapper = metaObject.getObjectWrapper();
            if (objectWrapper instanceof BeanWrapper) {
                BeanWrapper beanWrapper = (BeanWrapper) metaObject.getObjectWrapper();
                if (MPTBL_CM_TRAN_JOURNAL.equals(tableName)) {
                    log.debug("mapping table name :{}", tableName);

                  /*  ContextManager contextManager = ContextManagerImpl.getInstanse();
                    TableNameMapping tableNameMapping = contextManager.getContext(TableNameMapping.class);
                    String suffix = tableNameMapping.getSuffix(tableName);*/


                    //因update时 ParameterObject对象和insert时不一致,因此需要放弃使用mp的对象,用自定义对象获取表名后缀
                    /*
                    String delegate = beanWrapper.findProperty("delegate", true);

                    PropertyTokenizer prop2 = new PropertyTokenizer("delegate");
                    Object obj2 = beanWrapper.get(prop2);
                    PreparedStatementHandler ph = (PreparedStatementHandler) obj2;
                    Object bean = ph.getParameterHandler().getParameterObject();
                    //获取对象中分表属性
                    CmTranJournal cmTranJournal = (CmTranJournal) bean;
                    String suffix = cmTranJournal.getBusiType();
                    */
                    log.debug("mapping table name result:{}", tableName);
                    return tableName;
                }
            }
            //other table/bean not mapping tablename
            return null;
        };
        //defined which table to mapping
        Map<String, ITableNameHandler> tableNameHandlerMap = new HashMap<>();
        tableNameHandlerMap.put(MPTBL_CM_TRAN_JOURNAL, myTableNameHandler);
        dynamicTableNameParser.setTableNameHandlerMap(tableNameHandlerMap);
        sqlParserList.add(dynamicTableNameParser);
        paginationInterceptor.setSqlParserList(sqlParserList);
        paginationInterceptor.setDialectType(DbType.MYSQL.getDb());
        log.info("mybatis_plus_extend_plugin(paginationInterceptor): {}" + paginationInterceptor);
        return paginationInterceptor;
    }

}

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
可以通过以下方式将 tkmapper 和 mybatisplus 配置在同一个配置文件中: 1. 导入 tkmapper 和 mybatisplus 依赖包。 2. 配置 mybatisplus 的数据源和 mapper 扫描路径,例如: ```properties # mybatisplus 数据库配置 spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&serverTimezone=Asia/Shanghai spring.datasource.username=root spring.datasource.password=root # mybatisplus mapper 扫描路径 mybatis-plus.mapper-locations=classpath*:mapper/**/*.xml ``` 3. 配置 tkmapper 的 mapper 扫描路径,例如: ```properties # tkmapper mapper 扫描路径 tk.mybatis.mapper.mapper-locations=classpath:mapper/*.xml ``` 4. 在 Mybatis 配置类中,分别配置 mybatisplus 和 tkmapper 的插件和拦截器,例如: ```java @Configuration public class MybatisConfig { @Bean public PaginationInterceptor paginationInterceptor() { return new PaginationInterceptor(); } @Bean public MapperInterceptor mapperInterceptor() { return new MapperInterceptor(); } @Bean public ConfigurationCustomizer configurationCustomizer() { return new ConfigurationCustomizer() { @Override public void customize(Configuration configuration) { configuration.setUseGeneratedKeys(true); configuration.setCacheEnabled(false); } }; } @Bean public MapperScannerConfigurer mapperScannerConfigurer() { MapperScannerConfigurer configurer = new MapperScannerConfigurer(); configurer.setBasePackage("com.example.demo.mapper"); return configurer; } } ``` 以上是基本的配置方式,具体的细节还需要根据实际情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值