【解决sql日志无法输出问题】

本文介绍了如何在Spring Boot应用中解决SQL日志无法输出的问题,提供了两种解决方案:通过application.yml文件配置和使用Java类配置。只需选择一种方式进行设置,当同时存在两种配置时,以yml文件配置为准。
部署运行你感兴趣的模型镜像

解决springboot日志不打印日志问题


问题:控制台不打印或者日志文件不打印mybatis的sql日志

application.yml中增加配置文件

#  mybatis-plus配置
mybatis-plus:
  mapper-locations: classpath:com/innovation/ic/cyz/base/mapper/**/*Mapper.xml
  typeAliasesPackage: com.innovation.ic.cyz.base.model
  configuration:
    map-underscore-to-camel-case: true
    ## log-impl: org.apache.ibatis.logging.stdout.StdOutImpl 打印控制台
    ## 下面输出到日志文件中
    log-impl: org.apache.ibatis.logging.slf4j.Slf4jImpl
  mybatis-plus-print-log: true

也可以使用java类配置

俩种方式二选一。当俩种配置类有时,下面的配置起作用

package com.innovation.ic.cyz.web.config;

import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.core.MybatisConfiguration;
import com.baomidou.mybatisplus.core.config.GlobalConfig;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean;
import com.innovation.ic.cyz.base.pojo.constant.DatabaseGlobal;
import org.apache.ibatis.logging.Log;
import org.apache.ibatis.logging.slf4j.Slf4jImpl;
import org.apache.ibatis.logging.stdout.StdOutImpl;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.type.JdbcType;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.transaction.annotation.EnableTransactionManagement;

import javax.sql.DataSource;
import java.util.HashMap;
import java.util.Map;

@EnableTransactionManagement
@Configuration
@MapperScan("com.innovation.ic.cyz.base.mapper," +
        "com.innovation.ic.cyz.base.mapper.cyz," +
        "com.innovation.ic.cyz.base.mapper.pve_standard")
public class MybatisPlusConfig {

    //需要注入的Bean
    @Bean
    public EasySqlInjector easySqlInjector() {
        return new EasySqlInjector();
    }

    @Bean
    public PaginationInterceptor paginationInterceptor() {
        return new PaginationInterceptor();
    }

//    @Bean(name = DatabaseGlobal.IM_ERP9)
//    @ConfigurationProperties(prefix = "spring.datasource.im-erp9")
//    public DataSource imErp9() {
//        return DruidDataSourceBuilder.create().build();
//    }
//
//    @Bean(name = DatabaseGlobal.IM_B1B)
//    @ConfigurationProperties(prefix = "spring.datasource.im-b1b")
//    public DataSource imB1b() {
//        return DruidDataSourceBuilder.create().build();
//    }

    @Bean(name = DatabaseGlobal.CYZ)
    @ConfigurationProperties(prefix = "spring.datasource.cyz")
    public DataSource cyz() {
        return DruidDataSourceBuilder.create().build();
    }

    @Bean(name = DatabaseGlobal.PVE_STANDARD)
    @ConfigurationProperties(prefix = "spring.datasource.pve-standard")
    public DataSource pveStandard() {
        return DruidDataSourceBuilder.create().build();
    }

    /**
     * 动态数据源配置
     *
     * @return
     */
    @Bean
    @Primary
    public DataSource multipleDataSource(/*@Qualifier(DatabaseGlobal.IM_ERP9) DataSource imErp9DataSource,
                                         @Qualifier(DatabaseGlobal.IM_B1B) DataSource imB1bDataSource,*/
                                         @Qualifier(DatabaseGlobal.CYZ) DataSource imCyzDataSource,
                                         @Qualifier(DatabaseGlobal.PVE_STANDARD) DataSource imStandardDataSource
                                         ) {
        DynamicDataSource dynamicDataSource = new DynamicDataSource();
        Map<Object, Object> targetDataSources = new HashMap<Object, Object>();
//        targetDataSources.put(DatabaseGlobal.IM_ERP9, imErp9DataSource);
//        targetDataSources.put(DatabaseGlobal.IM_B1B, imB1bDataSource);
        targetDataSources.put(DatabaseGlobal.CYZ, imCyzDataSource);
        targetDataSources.put(DatabaseGlobal.PVE_STANDARD, imStandardDataSource);
        dynamicDataSource.setTargetDataSources(targetDataSources);
        // 程序默认数据源,这个要根据程序调用数据源频次,经常把常调用的数据源作为默认
        dynamicDataSource.setDefaultTargetDataSource(cyz());
        return dynamicDataSource;
    }

    @Bean("sqlSessionFactory")
    public SqlSessionFactory sqlSessionFactory() throws Exception {
        MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean();
        sqlSessionFactory.setDataSource(multipleDataSource(/*imErp9(), imB1b(),*/ cyz(), pveStandard()));

        MybatisConfiguration configuration = new MybatisConfiguration();
        configuration.setJdbcTypeForNull(JdbcType.NULL);
        configuration.setMapUnderscoreToCamelCase(true);
        configuration.setCacheEnabled(false);
		// todo 这个必须设置,否则sql日志无法输出
        configuration.setLogImpl(StdOutImpl.class);
        sqlSessionFactory.setConfiguration(configuration);
        sqlSessionFactory.setGlobalConfig(globalConfiguration());
        // 乐观锁插件
        //PerformanceInterceptor(),OptimisticLockerInterceptor()
        // 分页插件
        sqlSessionFactory.setPlugins(paginationInterceptor());
        return sqlSessionFactory.getObject();
    }

    @Bean
    public GlobalConfig globalConfiguration() {
        GlobalConfig conf = new GlobalConfig();
        // 自定义的注入需要在这里进行配置
        conf.setSqlInjector(easySqlInjector());
        return conf;
    }

    /**
     * 分页插件配置
     *
     * @return
     */
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        // 向MyBatis-Plus的过滤器链中添加分页拦截器,需要设置数据库类型(主要用于分页)
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }
}


您可能感兴趣的与本文相关的镜像

ComfyUI

ComfyUI

AI应用
ComfyUI

ComfyUI是一款易于上手的工作流设计工具,具有以下特点:基于工作流节点设计,可视化工作流搭建,快速切换工作流,对显存占用小,速度快,支持多种插件,如ADetailer、Controlnet和AnimateDIFF等

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

心有城府,腹有良谋

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值