JPA 打印sql参数

博客指出 Spring Boot 2.x 的日志级别是小写的,并展示了相应效果,聚焦于该框架日志级别的特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  jpa:
#    show-sql: true
    properties:
#      hibernate:
#        format_sql: true
#        use_sql_comments: true
    database-platform: org.hibernate.dialect.MySQL5InnoDBDialect
    hibernate:
      ddl-auto: update
logging:
  level:
    org.springframework.security:
      - debug
      - info
    org.springframework.web: error
    org.hibernate.SQL: debug
    org.hibernate.engine.QueryParameters: debug
    org.hibernate.engine.query.HQLQueryPlan: debug
    org.hibernate.type.descriptor.sql.BasicBinder: trace

springboot 2.x 日志级别是小写的
展示效果
日志

<think>嗯,用户想知道如何在Spring Boot中配置JPA打印包含动态参数SQL日志。我记得在Spring Boot中,JPA默认使用的是Hibernate作为实现,所以可能需要调整Hibernate的日志设置。不过用户特别提到要显示动态参数,也就是实际传入的参数值,而不是预编译的带问号的语句。 首先,我需要确定JPA的日志配置通常是在application.properties或者application.yml文件中进行的。根据之前的引用内容,用户可能已经了解如何配置自定义属性,比如@Value和@ConfigurationProperties的使用。但这里涉及到的是日志级别的设置,特别是Hibernate的日志级别。 根据引用4中提到,用户可以通过application.properties来配置常量,这可能包括日志相关的配置。Hibernate有几个日志相关的属性,比如spring.jpa.show-sql,但默认情况下这个属性只会打印SQL语句,而不会显示参数。因此,需要更详细的日志配置。 我记得Hibernate有一个参数叫做format_sql,可以格式化SQL语句,但这可能还不够。要显示实际的参数值,可能需要启用Hibernate的调试日志级别,或者设置特定的日志记录器。此外,可能需要配置日志框架(如Logback或Log4j2)来输出绑定参数的信息。 在引用2中,提到了Flyway的配置,可能与日志无关,但用户可能需要参考类似的配置结构。例如,设置日志级别通常使用logging.level.*属性。比如,logging.level.org.hibernate.SQL=DEBUG可以显示SQL语句,而logging.level.org.hibernate.type.descriptor.sql.BasicBinder=TRACE可以显示绑定参数的值。 另外,用户可能还需要禁用SQL格式化,以便看到原始的带参数的语句。可能需要设置spring.jpa.properties.hibernate.format_sql=false,这样日志就不会美化SQL,导致参数占位符被替换。 还需要注意,不同的Spring Boot版本可能有不同的默认配置,所以需要确认这些配置在当前版本中是否适用。此外,如果用户使用的是不同的JPA实现(比如EclipseLink),配置方式可能会不同,但根据常见情况,假设用户使用Hibernate。 总结下来,配置步骤可能包括: 1. 在application.properties中启用Hibernate的SQL日志。 2. 设置日志级别以显示绑定参数。 3. 禁用SQL格式化以确保参数正确显示。 4. 可能需要调整日志框架的配置,确保TRACE级别的日志被输出。 需要检查这些步骤是否正确,并确保示例中的配置代码准确无误。同时,用户可能需要根据实际使用的日志框架进行适当的调整,比如Logback需要对应的配置文件(如logback-spring.xml)来定义输出格式。不过根据用户的问题,可能只需要在application.properties中添加相关属性即可。</think>### Spring Boot配置JPA打印带动态参数SQL日志 在Spring Boot中配置JPA打印包含动态参数SQL日志,需通过Hibernate的日志级别控制实现。以下是具体步骤: #### 1. 修改`application.properties`配置 添加以下配置启用SQL日志及参数绑定信息: ```properties # 显示原始SQL(禁用格式化) spring.jpa.properties.hibernate.format_sql=false # 启用SQL日志输出 logging.level.org.hibernate.SQL=DEBUG # 显示绑定参数的具体值 logging.level.org.hibernate.type.descriptor.sql.BasicBinder=TRACE ``` #### 2. 配置解释 - `spring.jpa.properties.hibernate.format_sql=false` 禁用SQL格式化,避免日志中参数占位符`?`被换行干扰可读性[^4]。 - `logging.level.org.hibernate.SQL=DEBUG` 输出Hibernate生成的原始SQL语句,包含占位符`?`[^1]。 - `logging.level.org.hibernate.type.descriptor.sql.BasicBinder=TRACE` 显示动态参数的实际绑定值(如`Query:select ... where id=?`会显示为`binding parameter [1] as [VARCHAR] - '1001'`)[^3]。 #### 3. 日志输出示例 启用后日志会显示: ```sql DEBUG o.h.SQL - select u from User u where u.name=? TRACE o.h.t.d.s.BasicBinder - binding parameter [1] as [VARCHAR] - '张三' ``` #### 4. 高级配置(可选) 如需完整SQL语句拼接效果,可结合日志框架(如Logback)自定义日志格式: ```xml <!-- logback-spring.xml --> <configuration> <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"> <encoder> <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> </appender> <logger name="org.hibernate.SQL" level="DEBUG"/> <logger name="org.hibernate.type.descriptor.sql" level="TRACE"/> <root level="INFO"> <appender-ref ref="CONSOLE"/> </root> </configuration> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值