springboot自定义日志类型并且打印mybatis的sql语句

首先呢springboot 使用的是 logback做为默认的日志记录方式,但是如果我想用log4j记录日志怎么办呢

第一步:将logback依赖排除,因为springboot-starter-web 会自动依赖logback 包

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>2.0.1.RELEASE</version>
            <!-- 排除默认的logback日志,使用log4j-->
            <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
            </exclusion>
            </exclusions>
        </dependency>
        <!--swagger -->
       <dependency>

第二步:增加og4j-core依赖,否则springboot各种启动日志不会打印

       <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-core</artifactId>
            <version>2.10.0</version>
        </dependency>

不加的话会出现如下错:ERROR StatusLogger Log4j2 could not find a logging implementation. Please add log4j-core to the classpath. Using SimpleLogger to log to the console...

case1 :最后能够打印出springboot和我们手动记录以及mybatis的sql语句,在这个地方估计你会觉得很奇怪,我没看见我引入了log4j的依赖啊,为什么最后还是可以打印呢?

针对这个问题,你可一看看你项目中是否有其他jar引入过log4j的依赖

case2: 最后没打印出来,那么你就手动加入log4j的依赖


 

 

 

 

### 如何在 Spring Boot 中使用 MyBatis 打印完整 SQL 日志 要在 Spring Boot 项目中配置 MyBatis打印完整的 SQL 日志,可以通过调整 `application.properties` 文件中的日志级别以及引入合适的依赖来实现。 #### 1. 添加必要的依赖 为了支持 MyBatis 和其日志功能,在项目的 `pom.xml` 文件中需加入以下依赖项: ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.3.0</version> </dependency> <!-- 如果未默认包含logback,则手动添加 --> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> </dependency> ``` 上述代码片段展示了如何引入 `mybatis-spring-boot-starter`[^2] 及 Logback 支持的日志框架。 #### 2. 配置 application.properties 文件 通过修改 `application.properties` 文件可以启用调试模式并显示详细的 SQL 查询信息。以下是具体的配置参数: ```properties # 设置Mapper接口所在的包路径下的日志等级为DEBUG logging.level.com.example.mapper=debug # (可选)如果需要更细粒度的控制,也可以指定特定Mapper类名 logging.level.com.example.mapper.UserMapper=trace ``` 这里设置了 Mapper 接口所在包的日志级别为 `debug`,从而能够捕获到执行的 SQL 语句及其绑定参数[^4]。 #### 3. 使用Logback自定义日志格式(可选) 对于希望进一步美化或者过滤输出内容的情况,可以在 `src/main/resources/logback-spring.xml` 定义个性化规则: ```xml <?xml version="1.0" encoding="UTF-8"?> <configuration> <!-- 控制台输出 --> <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> <encoder> <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> </appender> <!-- 设定MyBatis相关Logger --> <logger name="com.example.mapper" level="DEBUG"/> <root level="INFO"> <appender-ref ref="STDOUT" /> </root> </configuration> ``` 此部分允许开发者更加灵活地管理不同模块产生的日志数据[^1]。 完成以上步骤之后,当应用程序运行时,所有的SQL查询都会被记录下来,并且会连同实际传入数据库的具体值一同展示出来[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

坑里水库

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

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

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

打赏作者

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

抵扣说明:

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

余额充值