【无标题】

import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.autoconfigure.ConfigurationCustomizer;
import com.baomidou.mybatisplus.core.MybatisConfiguration;
import com.baomidou.mybatisplus.extension.incrementer.H2KeyGenerator;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.OptimisticLockerInnerInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean;
import org.apache.ibatis.logging.stdout.StdOutImpl;
import org.apache.ibatis.plugin.Interceptor;
import org.mybatis.spring.mapper.MapperScannerConfigurer;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;

import javax.sql.DataSource;
import java.io.IOException;

/**

  • @description:
  • @author: lingwanxian
  • @date: 2022/3/4 17:58
    /
    @Configuration
    public class MybatisPlusConfig {
    /
    *
    • mybatis-plus分页插件

    • 文档:http://mp.baomidou.com
      */
      // @Bean
      // public MybatisPlusInterceptor mybatisPlusInterceptor() {
      // MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
      // interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
      // return interceptor;
      // }

      @Bean
      public MybatisPlusInterceptor mybatisPlusInterceptor(){
      MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
      PaginationInnerInterceptor innerInterceptor=new PaginationInnerInterceptor();
      innerInterceptor.setDbType(DbType.MYSQL);
      innerInterceptor.setOverflow(true);
      interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
      interceptor.addInnerInterceptor(innerInterceptor);
      return interceptor;
      }

      @Bean
      public ConfigurationCustomizer configurationCustomizer(){
      return mybatisConfiguration -> mybatisConfiguration.setUseGeneratedShortKey(false);
      }

      /**

      • 相当于顶部的:
      • {@code @MapperScan(“com.baomidou.springboot.mapper*”)}
      • 这里可以扩展,比如使用配置文件来配置扫描Mapper的路径
        /
        @Bean
        public MapperScannerConfigurer mapperScannerConfigurer() {
        MapperScannerConfigurer scannerConfigurer = new MapperScannerConfigurer();
        scannerConfigurer.setBasePackage("com.analysis.dao.mapper
        ");
        return scannerConfigurer;
        }

      @Bean
      public H2KeyGenerator getH2KeyGenerator() {
      return new H2KeyGenerator();
      }

      //mybatis-plus里面这配置比较重要
      @Bean
      @ConfigurationProperties(prefix = “mybatis”)
      public MybatisSqlSessionFactoryBean mybatisSqlSessionFactoryBean(DataSource dataSource, MybatisPlusInterceptor mybatisPlusInterceptor) throws IOException {
      MybatisSqlSessionFactoryBean sessionFactoryBean = new MybatisSqlSessionFactoryBean();
      MybatisConfiguration configuration = new MybatisConfiguration();
      PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
      configuration.setMapUnderscoreToCamelCase(true); //下划线转骆驼
      Interceptor[] plugins = {mybatisPlusInterceptor};

       sessionFactoryBean.setPlugins(plugins);
       sessionFactoryBean.setDataSource(dataSource);
       sessionFactoryBean.setConfiguration(configuration);
       // 配置打印sql语句
       configuration.setLogImpl(StdOutImpl.class);
       sessionFactoryBean.setMapperLocations(resolver.getResources("classpath*:mapper/*Mapper.xml"));
      
       return sessionFactoryBean;
      

      }
      }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值