Springboot整合mybatis,配置logback日志 ,并打印sql

logback-spring.xml文件内容:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!-- 默认的一些配置 -->
    <include resource="org/springframework/boot/logging/logback/defaults.xml"/>
    <!-- 定义应用名称,区分应用 -->
    <property name="APP_NAME" value="task-service"/>
    <!-- 定义日志文件的输出路径 -->
    <property name="LOG_PATH" value="./logs/${APP_NAME}"/>

    <!-- 定义日志文件名称和路径 -->
    <property name="LOG_FILE" value="${LOG_PATH}/application.log"/>
    <!-- 定义警告级别日志文件名称和路径 -->
    <property name="WARN_LOG_FILE" value="${LOG_PATH}/warn.log"/>
    <!-- 定义错误级别日志文件名称和路径 -->
    <property name="ERROR_LOG_FILE" value="${LOG_PATH}/error.log"/>
    <!-- 定义错误级别日志文件名称和路径 -->
    <property name="DEBUG_LOG_FILE" value="${LOG_PATH}/debug.log"/>
    <!-- 定义指定目录service日志文件名称和路径 -->
    <property name="SERVICE_LOG_FILE" value="${LOG_PATH}/service.log"/>

    <!-- 自定义控制台打印格式 -->
    <property name="FILE_LOG_PATTERN" value="%green(%d{yyyy-MM-dd HH:mm:ss.SSS}) [%blue(%X{trace_id})] [%highlight(%thread)] %highlight(%-5level) %logger{50} - %msg%n"/>
<!--    <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%X{trace_id}] [%thread] %-5level %logger{50} - %msg%n</pattern>-->
<!--    <property name="FILE_LOG_PATTERN" value="%green(%d{yyyy-MM-dd HH:mm:ss.SSS}) [%blue(traceId: %X{traceId})] [%highlight(%thread)] ${PID:- } %logger{36} %-5level - %msg%n"/>-->



    <!-- 将日志滚动输出到application.log文件中 -->
    <appender name="APPLICATION" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!-- 输出文件目的地 -->
        <file>${LOG_FILE}</file>
        <encoder>
            <!-- 使用默认的输出格式打印 -->
            <pattern>${FILE_LOG_PATTERN}</pattern>
            <charset>utf8</charset>
        </encoder>

        <!-- 设置 RollingPolicy 属性,用于配置文件大小限制,保留天数、文件名格式 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!-- 文件命
### 如何在 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值