Springboot JPA打印SQL语句及参数的实现

 更新时间:2024年06月19日 11:41:01   作者:爱偷懒的程序源  
在SpringBoot项目中调试和优化数据库操作是很常见的需求,本文主要介绍了Springboot JPA打印SQL语句及参数的实现,具有一定的参考价值,感兴趣的可以了解一下

背景

最近调试项目时需要打印sql语句以及参数,在网上搜了好久才找到一个最简单的解决方案,分享给大家。

项目使用的是springboot jpa来做数据的持久化,springboot版本为3.2.1,默认的hibernate版本是6.4.1.Final,由于版本太高,网上常见的配置都不起作用,话不多说,直接上解决方案

方法一

在application.properties文件中添加如下配置:

# 打印jpa的sql语句,注意这个配置会导致sql语句重复打印,如果开启了下面的配置,这个配置可以注释掉
spring.jpa.show-sql=true
# 打印sql语句及参数
logging.level.org.hibernate.SQL=DEBUG
logging.level.org.hibernate.type.descriptor.sql.BasicBinder=TRACE

如果用的是jdbcTemplate,需要这么配置

logging.level.org.springframework.jdbc.core.JdbcTemplate=DEBUG
logging.level.org.springframework.jdbc.core.StatementCreatorUtils=TRACE

方法一适用于低版本的hibernate

方法二

在application.properties文件中添加如下配置:

# 打印jpa的sql语句,注意这个配置会导致sql语句重复打印,如果开启了下面的配置,这个配置可以注释掉
spring.jpa.show-sql=true
# hibernate基础日志级别
logging.level.org.hibernate=INFO
# 打印sql语句及参数
logging.level.org.hibernate.SQL=DEBUG
logging.level.org.hibernate.orm.jdbc.bind=TRACE

方法二适用于hibernate版本在6以上。

方法三

在搜索的过程中发现有很多种打印sql的方法,如果想要优雅打印sql语句及参数需要自定义sql语句拦截器,这就不是一杯咖啡的时间可以搞定的了,有兴趣的读者可以自己探索下。

最终呈现的打印效果如下,虽然不太优雅,但是已经能否满足调试需求:

DEBUG 45929 --- [nio-8080-exec-1] org.hibernate.SQL                        : insert into user (age,name) values (?,?)
Hibernate: insert into user (age,name) values (?,?)
TRACE 45929 --- [nio-8080-exec-1] org.hibernate.orm.jdbc.bind              : binding parameter (1:INTEGER) <- [null]
TRACE 45929 --- [nio-8080-exec-1] org.hibernate.orm.jdbc.bind              : binding parameter (2:VARCHAR) <- [null]

后续有其他解决方案,会持续更新补充。更多相关Springboot JPA打印SQL内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java Comparator.comparing比较导致空指针异常的解决

    Java Comparator.comparing比较导致空指针异常的解决

    这篇文章主要介绍了Java Comparator.comparing比较导致空指针异常的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • Java编程接口详细

    Java编程接口详细

    这篇文章主要小编主要给大家讲解的是Java编程中的接口,文章会从抽象类和抽象方法开始展开内容,感兴趣的小伙伴可以参考下面文章的具体内容
    2021-10-10
  • Maven中错误使用parent.relativePath导致构建失败问题

    Maven中错误使用parent.relativePath导致构建失败问题

    这篇文章主要介绍了Maven中错误使用parent.relativePath导致构建失败问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • 聊聊Java的switch为什么不支持long

    聊聊Java的switch为什么不支持long

    这篇文章主要介绍了Java的switch为什么不支持long,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-10-10
  • Java使用lombok消除冗余代码的方法步骤

    Java使用lombok消除冗余代码的方法步骤

    这篇文章主要介绍了Java使用lombok消除冗余代码的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • RedisKey的失效监听器KeyExpirationEventMessageListener问题

    RedisKey的失效监听器KeyExpirationEventMessageListener问题

    这篇文章主要介绍了RedisKey的失效监听器KeyExpirationEventMessageListener问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • Scala递归函数调用自身

    Scala递归函数调用自身

    这篇文章主要介绍了Scala递归函数,Scala递归函数是一种函数可以调用自身的函数,直到满足某个特定的条件为止。在函数式编程的语言中,递归函数起着重要的作用,因为它可以用来表示循环或迭代的逻辑
    2023-04-04
  • Java SpringBoot集成ChatGPT实现AI聊天

    Java SpringBoot集成ChatGPT实现AI聊天

    ChatGPT已经组件放开了,现在都可以基于它写插件了,也许可以用它结合文字语音开发一个老人小孩需要的智能的说话陪伴啥的,这篇文章就介绍SpringBoot结合ChatGPT实现AI聊天感兴趣的同学可以借鉴一下
    2023-04-04
  • java之swing实现复选框的方法

    java之swing实现复选框的方法

    这篇文章主要介绍了java之swing实现复选框的方法,实例分析了java基于图形界面复选框的实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-09-09
  • IDEA2022.1创建maven项目规避idea2022新建maven项目卡死无反应问题

    IDEA2022.1创建maven项目规避idea2022新建maven项目卡死无反应问题

    这篇文章主要介绍了IDEA2022.1创建maven项目规避idea2022新建maven项目卡死无反应问题,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-08-08

最新评论