Spring Boot 中整合 MySQL 并打印 SQL 日志

在 Spring Boot 中整合 MySQL 并打印 SQL 日志,需通过配置数据源、JPA 及日志框架实现。以下是详细步骤及最佳实践:


一、添加依赖

pom.xml中引入 Spring Data JPA 和 MySQL 驱动依赖:

复制代码
<dependencies>
    <!-- Spring Data JPA -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    <!-- MySQL 驱动 -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <scope>runtime</scope>
    </dependency>
</dependencies>

二、配置数据源与 JPA

application.propertiesapplication.yml中配置 MySQL 连接及日志参数:

复制代码
# 数据源配置
spring.datasource.url=jdbc:mysql://localhost:3306/your_database?useSSL=false&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=your_password
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

# JPA 配置
spring.jpa.hibernate.ddl-auto=update        # 自动生成表结构(开发环境)
spring.jpa.show-sql=true                   # 开启 SQL 日志打印
spring.jpa.properties.hibernate.format_sql=true  # 格式化 SQL 语句

三、配置日志级别

通过日志框架(如 Logback)控制 SQL 日志的详细程度:

  1. **Logback 配置(logback-spring.xml)**​

    src/main/resources下创建文件,配置不同日志级别:

    复制代码
    <configuration>
        <!-- 打印 SQL 语句 -->
        <logger name="org.hibernate.SQL" level="DEBUG"/>
        <!-- 打印 SQL 参数(如占位符值) -->
        <logger name="org.hibernate.type.descriptor.sql.BasicTypeRegistry" level="TRACE"/>
        <!-- 打印 Hibernate 执行耗时 -->
        <logger name="org.hibernate.tool.schema.spi" level="TRACE"/>
    
        <root level="INFO">
            <appender-ref ref="CONSOLE"/>
        </root>
    </configuration>
  2. **Log4j2 配置(log4j2.xml)**​

    若使用 Log4j2,配置类似:

    复制代码
    <Configuration>
        <Loggers>
            <Logger name="org.hibernate.SQL" level="debug"/>
            <Logger name="org.hibernate.type.descriptor.sql.BasicTypeRegistry" level="trace"/>
            <Root level="info">
                <AppenderRef ref="Console"/>
            </Root>
        </Loggers>
    </Configuration>

四、验证日志输出

创建实体类和 Repository,触发数据库操作:

复制代码
@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;
    // getters/setters
}

@Repository
public interface UserRepository extends JpaRepository<User, Long> {}

// 在 Service 或 Controller 中调用
@Service
public class UserService {
    @Autowired
    private UserRepository userRepository;

    public User saveUser(User user) {
        return userRepository.save(user);
    }
}

启动应用后,控制台输出示例

复制代码
Hibernate: insert into user (name) values (?)
2025-11-17 14:12:00.123 TRACE 12345 --- [nio-8080-exec-1] o.h.type.descriptor.sql.BasicTypeRegistry : binding parameter [1] as [VARCHAR] - [John]

五、高级配置

  1. 自定义日志格式

    在 Logback 中调整时间戳、线程名等:

    复制代码
    <encoder>
        <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
    </encoder>
  2. 按环境控制日志级别

    application-prod.yml中关闭调试日志:

    复制代码
    logging:
      level:
        org.hibernate.SQL: WARN

六、注意事项

  • 生产环境 :避免开启 TRACE级别,防止敏感信息泄露。

  • 性能影响TRACE级别会记录参数绑定细节,可能影响性能。

  • SQL 优化:通过日志分析慢查询,结合索引优化数据库性能。


通过以上配置,可清晰监控 Spring Boot 与 MySQL 的交互细节,适用于开发调试和性能分析。如需进一步定制,可参考 Spring Boot 官方文档

相关推荐
草履虫建模9 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
qq_2975746712 小时前
【实战教程】SpringBoot 实现多文件批量下载并打包为 ZIP 压缩包
java·spring boot·后端
老毛肚12 小时前
MyBatis插件原理及Spring集成
java·spring·mybatis
学嵌入式的小杨同学12 小时前
【Linux 封神之路】信号编程全解析:从信号基础到 MP3 播放器实战(含核心 API 与避坑指南)
java·linux·c语言·开发语言·vscode·vim·ux
lang2015092812 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
Re.不晚12 小时前
Java入门17——异常
java·开发语言
缘空如是12 小时前
基础工具包之JSON 工厂类
java·json·json切换
追逐梦想的张小年13 小时前
JUC编程04
java·idea
好家伙VCC13 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
南极星100513 小时前
蓝桥杯JAVA--启蒙之路(十)class版本 模块
java·开发语言