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

想在Hibernate里看到它执行的SQL?简单,几个小技巧就能搞定。
Hibernate打印SQL语句,其实就是配置的问题,目标是让Hibernate把生成的SQL显示出来,方便我们调试和优化。
解决方案
修改Hibernate配置文件(hibernate.cfg.xml 或 persistence.xml):
这是最常见的方法。在你的Hibernate配置文件中,添加或修改以下属性:
truetrue
hibernate.show_sql
设为
true
会让Hibernate在控制台打印SQL语句。
hibernate.format_sql
设为
true
会格式化SQL,让它更易读。个人建议两个都设为
true
。
使用日志框架:
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
中添加如下配置:
晓语台
晓语台,是一款AI文本创作产品。创作能力主要围绕营销文本的AI创作,晓语台覆盖了品牌与市调、商业媒体、社交媒体、搜索营销、数字广告、职场办公共六类全营销文本
34 查看详情
log4j.logger.org.hibernate.SQL=DEBUGlog4j.logger.org.hibernate.type.descriptor.sql.BasicBinder=TRACElog4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.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
控制参数输出。
在代码中配置:
如果你不想修改配置文件,也可以在代码中动态设置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执行情况。
以上就是hibernate 中如何在控制台查看打印的sql 语句?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/595811.html
微信扫一扫
支付宝扫一扫