hibernate 中如何在控制台查看打印的sql 语句?

答案:通过配置hibernate.show_sql和hibernate.format_sql属性为true,或使用日志框架如logbacklog4j设置org.hibernate.SQL为DEBUG级别,即可在控制台查看Hibernate执行的sql语句

hibernate 中如何在控制台查看打印的sql 语句?

想在Hibernate里看到它执行的SQL?简单,几个小技巧就能搞定。

Hibernate打印SQL语句,其实就是配置的问题,目标是让Hibernate把生成的SQL显示出来,方便我们调试和优化。

解决方案

  1. 修改Hibernate配置文件(hibernate.cfg.xml 或 persistence.xml):

    这是最常见的方法。在你的Hibernate配置文件中,添加或修改以下属性:

    <property name="hibernate.show_sql">true</property> <property name="hibernate.format_sql">true</property>
    hibernate.show_sql

    设为

    true

    会让Hibernate在控制台打印SQL语句。

    hibernate.format_sql

    设为

    true

    会格式化SQL,让它更易读。个人建议两个都设为

    true

  2. 使用日志框架:

    Hibernate底层使用SLF4J作为日志门面,所以你可以通过配置SLF4J绑定的具体日志实现(比如Logback或Log4j)来控制SQL的输出。

    • Logback:

      logback.xml

      中添加如下配置:

      <configuration>     <appender name="STDOUT" 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" additivity="false">         <appender-ref ref="STDOUT" />     </logger>      <logger name="org.hibernate.type.descriptor.sql.BasicBinder" level="TRACE" additivity="false">         <appender-ref ref="STDOUT" />     </logger>      <root level="ERROR">         <appender-ref ref="STDOUT" />     </root> </configuration>
      org.hibernate.SQL

      logger负责输出SQL语句,

      org.hibernate.type.descriptor.sql.BasicBinder

      logger负责输出SQL参数。

    • Log4j:

      log4j.properties

      中添加如下配置:

      log4j.logger.org.hibernate.SQL=DEBUG log4j.logger.org.hibernate.type.descriptor.sql.BasicBinder=TRACE log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender.stdout.layout=org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern=%d{HH:mm:ss.SSS} [%t] %-5p %c{1} - %m%n

      同样,

      org.hibernate.SQL

      控制SQL输出,

      org.hibernate.type.descriptor.sql.BasicBinder

      控制参数输出。

  3. 在代码中配置:

    如果你不想修改配置文件,也可以在代码中动态设置Hibernate的属性:

    Configuration configuration = new Configuration(); configuration.setProperty("hibernate.show_sql", "true"); configuration.setProperty("hibernate.format_sql", "true"); // 其他配置... SessionFactory sessionFactory = configuration.buildSessionFactory();

    这种方法更灵活,但每次启动应用都需要设置。

如何在Hibernate中查看SQL参数?

仅仅看到SQL语句是不够的,有时候我们还需要知道SQL语句中的参数是什么。这可以通过配置日志框架来实现,就像上面提到的

org.hibernate.type.descriptor.sql.BasicBinder

logger。启用这个logger的TRACE级别,你就能在控制台看到Hibernate绑定的参数值。

另外,有些ide(比如IntelliJ idea)提供了插件,可以拦截Hibernate的SQL语句,并显示参数值,用起来更方便。

为什么配置了hibernate.show_sql=true,还是看不到SQL?

这通常有几个原因:

  • 日志级别问题: 检查你的日志框架配置,确保Hibernate SQL logger的级别设置为DEBUG或更低(比如TRACE)。如果你的root logger级别设置得太高,可能会屏蔽掉Hibernate的SQL输出。
  • 配置文件位置错误: 确保你的Hibernate配置文件(
    hibernate.cfg.xml

    persistence.xml

    )放在正确的位置,并且被正确加载。

  • 多个Hibernate配置: 如果你的项目中有多个Hibernate配置,确保你修改的是正在使用的那个。
  • 缓存问题: 有时候Hibernate使用了二级缓存,导致没有实际执行SQL。尝试禁用二级缓存,看看是否能看到SQL。
  • 事务问题: 确保你的代码在事务中执行数据库操作。如果不在事务中,Hibernate可能不会立即执行SQL。

Hibernate SQL输出太多,如何过滤掉不需要的SQL?

Hibernate的SQL输出可能会很冗长,特别是当你的应用频繁操作数据库时。为了过滤掉不需要的SQL,你可以:

  • 调整日志级别:
    org.hibernate.SQL

    logger的级别设置为INFO或WARN,只显示重要的SQL语句,比如更新或删除操作。

  • 使用自定义日志过滤器: 编写自定义的日志过滤器,根据SQL语句的内容进行过滤。这需要你熟悉日志框架的API。
  • 使用SQL Profiler: 使用专业的SQL Profiler工具(比如mysql Profiler或SQL Server Profiler)来监控数据库的SQL执行情况。这些工具通常提供了更强大的过滤和分析功能。

总的来说,让Hibernate在控制台打印SQL语句并不难,关键是理解Hibernate的配置和日志机制。根据你的实际需求,选择合适的方法,就能轻松地监控和调试Hibernate的SQL执行情况。

© 版权声明
THE END
喜欢就支持一下吧
点赞13 分享