如何通过Log4J 2查看Hibernate 的SQL输入参数?

栏目: Hibernate · 发布时间: 6年前

内容简介:在没有看到和检查背后运行的SQL以及相应的绑定输入参数的情况下,我们很容易引入可能长时间存在的性能损失(例如N + 1)。如果您的项目中已经有Log4J 2,则下面介绍的解决方案非常有用。如果没有,最好依赖于TRACE或log4jdbc(谢谢谢尔盖·波兹南斯基的建议和基于Log4J 2的描述:在开发应用程序时,维护对于查看和检查预准备的语句绑定参数值而不是假设它们很有用。一种方法是通过Log4J 2记录器设置。

在没有看到和检查背后运行的 SQL 以及相应的绑定输入参数的情况下,我们很容易引入可能长时间存在的性能损失(例如N + 1)。

如果您的项目中已经有Log4J 2,则下面介绍的解决方案非常有用。如果没有,最好依赖于TRACE或log4jdbc(谢谢谢尔盖·波兹南斯基的建议和 SO 解决方式)。这两种方法都不需要排除Spring Boot的默认日志记录。TRACE例子可以发现 在这里 ,例子log4jdbc 在这里 。 

基于Log4J 2的描述:在开发应用程序时,维护对于查看和检查预准备的语句绑定参数值而不是假设它们很有用。一种方法是通过Log4J 2记录器设置。

关键点:

  • 对于Maven,在中pom.xml,排除Spring Boot的默认日志记录(上面的读取更新)
  • 对于Maven,在中pom.xml,添加Log4j 2依赖项
  • 在log4j2.xml, 添加以下内容:

源代码可以在 这里 找到  


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Unity 3D脚本编程

Unity 3D脚本编程

陈嘉栋 / 电子工业出版社 / 2016-9-1 / 79

《Unity 3D脚本编程——使用C#语言开发跨平台游戏》以Unity 3D 的跨平台基础Mono,以及其游戏脚本语言C#为基础进行讲解。全面系统地剖析了Unity 3D 的跨平台原理以及游戏脚本开发的特点。 第1 章主要介绍了Unity 3D 引擎的历史以及编辑器的基本知识;第2 章主要介绍了Mono,以及Unity3D 利用Mono 实现跨平台的原理,并且分析了C#语言为什么更适合Uni......一起来看看 《Unity 3D脚本编程》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

SHA 加密
SHA 加密

SHA 加密工具