0

0

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

畫卷琴夢

畫卷琴夢

发布时间:2025-08-29 08:12:01

|

468人浏览过

|

来源于php中文网

原创

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

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

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

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

解决方案

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

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

    true
    true

    hibernate.show_sql
    设为
    true
    会让Hibernate在控制台打印SQL语句。
    hibernate.format_sql
    设为
    true
    会格式化SQL,让它更易读。个人建议两个都设为
    true

  2. 使用日志框架:

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

    • Logback:

      logback.xml
      中添加如下配置:

      
          
              
                  %d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
              
          
      
          
              
          
      
          
              
          
      
          
              
          
      

      org.hibernate.SQL
      logger负责输出SQL语句,
      org.hibernate.type.descriptor.sql.BasicBinder
      logger负责输出SQL参数。

    • Log4j:

      log4j.properties
      中添加如下配置:

      Copy Leaks
      Copy Leaks

      AI内容检测和分级,帮助创建和保护原创内容

      下载
      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执行情况。

相关文章

全能打印神器
全能打印神器

全能打印神器是一款非常好用的打印软件,可以在电脑、手机、平板电脑等设备上使用。支持无线打印和云打印,操作非常简单,使用起来也非常方便,有需要的小伙伴快来保存下载体验吧!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

682

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

347

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1095

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

676

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

575

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

417

2024.04.29

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

72

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号