MyBatisPlus 日志的两个坑:生产环境不打日志、多数据源日志配置等

背景

MyBatis 日志打印踩过三次坑,本文总结这三个问题。

  1. 生产环境下怎么打印 MyBatis 日志。
  2. 多数据源时,配置 mybatis-plus 日志不生效问题。
  3. mybatis-plus 的 log-impl 属性值。

mybatis-plus 的 log-impl 属性值

org.apache.ibatis.logging.stdout.StdOutImpl 可以打印控制台日志,如果要输出 DAO 类的 debug 级别的日志,可以配置:

logging:
  level:
    com.xx.xx.*.dao: debug
复制代码

生产环境下,需要配置成另一个类:

mybatis-plus:
  configuration:
    # 开启驼峰命名规则自动转换
    map-underscore-to-camel-case: true
    # 日志打印
    log-impl: org.apache.ibatis.logging.slf4j.Slf4jImpl
复制代码

需要注意的是,这两个日志实现类的路径不相同,今天犯了一个低级错误,配置生产文件时,直接拷贝了最后一个类名称,导致日志配置错误,程序启动失败。

多数据源失效问题

多数据源时,默认的 mybatis-plus 配置不生效,需要单独对对应的数据源配置:

// 注入 MyBatisPlus 的配置属性
    @Bean
    @ConfigurationProperties(prefix = "mybatis-plus.configuration")
    public MybatisConfiguration globalConfiguration() {
        return new MybatisConfiguration();
    }

    // 特定的数据源
    @Bean(name = "myDataSource")
    @ConfigurationProperties(prefix = "spring.datasource.myDataSource")
    public DataSource testDataSource() {
        return DataSourceBuilder.create().build();
    }

    // 数据源作用的会话工厂对象
    @Bean(name = "mySqlSessionFactory")
    public SqlSessionFactory testSqlSessionFactory(@Qualifier("myDataSource") DataSource dataSource, MybatisConfiguration config) throws Exception {
        MybatisSqlSessionFactoryBean bean = new MybatisSqlSessionFactoryBean();
        bean.setDataSource(dataSource);
        bean.setPlugins(new Interceptor[]{paginationInterceptor});
        // 当前数据源作用的 Mapper 的配置信息
        bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:xxx/*.xml"));
        // 设置当前数据源的配置
        bean.setConfiguration(config);

        return bean.getObject();
    }
复制代码

启示录

mybatis-plus 的 log-impl 属性值,必须保证实现类的全称的正确,谨以此文总结今天遇到的低级错误。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 MyBatis-Plus 中配置数据可以通过以下步骤完成: 1. 添加相关依赖:首先,在项目的 `pom.xml` 文件中添加 MyBatis-Plus 和数据库驱动的依赖。例如,如果你使用的是 MySQL 数据库,可以添加如下依赖: ```xml <dependencies> <!-- MyBatis-Plus --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>最新版本</version> </dependency> <!-- MySQL 驱动 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>最新版本</version> </dependency> </dependencies> ``` 2. 配置数据:在项目的配置文件(例如 `application.yml` 或 `application.properties`)中,配置多个数据的连接信息。每个数据需要指定其对应的数据库驱动、URL、用户名和密码。例如: ```yaml spring: datasource: # 默认数据配置 url: jdbc:mysql://localhost:3306/db1 username: root password: password # 第二个数据配置 datasource2: url: jdbc:mysql://localhost:3306/db2 username: root password: password ``` 3. 配置数据:在配置类中,使用 `@Configuration` 注解标记该类为配置类,并使用 `@EnableTransactionManagement` 注解开启事务管理。然后,通过 `@Bean` 注解创建多个数据,并将它们注入到 `DataSource` 类中。例如: ```java @Configuration @EnableTransactionManagement public class DataSourceConfig { @Bean @ConfigurationProperties("spring.datasource") public DataSource dataSource() { return new DruidDataSource(); } @Bean @ConfigurationProperties("spring.datasource.datasource2") public DataSource dataSource2() { return new DruidDataSource(); } } ``` 4. 配置 MyBatis-Plus:在配置类中,使用 `@MapperScan` 注解指定要扫描的 Mapper 接口的包路径,并在 `SqlSessionFactory` 上配置多个数据。例如: ```java @Configuration @MapperScan(basePackages = "com.example.mapper") public class MybatisPlusConfig { @Autowired private DataSource dataSource; @Autowired private DataSource dataSource2; @Bean public SqlSessionFactory sqlSessionFactory() throws Exception { MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean(); sqlSessionFactory.setDataSource(dataSource); // 配置数据 MybatisConfiguration configuration = new MybatisConfiguration(); MapperRegistry mapperRegistry = new MapperRegistry(configuration); mapperRegistry.setKnownMappers(Collections.singletonList(BaseMapper.class)); sqlSessionFactory.setMapperRegistry(mapperRegistry); // 添加第二个数据 SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean(); factoryBean.setDataSource(dataSource2); factoryBean.setConfiguration(configuration); return sqlSessionFactory.getObject(); } } ``` 以上就是在 MyBatis-Plus 中配置数据的步骤。配置完成后,你可以在需要使用特定数据的地方使用 `@Qualifier` 注解指定要使用的数据。例如,在 Service 类中使用多数据: ```java @Service public class UserService { @Autowired @Qualifier("dataSource2") private DataSource dataSource; // 其他方法... } ``` 请注意,以上示例中使用了 Druid 数据库连接池,你也可以根据自己的需求选择其他连接池。另外,示例中的配置是基于 Spring Boot 的,如果你使用的是其他框架或纯 Spring 环境,请相应调整配置方式。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值