当我们开发任何应用程序,完成它或结束其任何模块时,我们都会开始优化过程。 大多数应用程序都包含数据库访问权限,并且如果您使用的是ORM ,则可能会使用hibernate 。 优化休眠持久层,要求准备阅读,理解和评估sql

如果我们对休眠配置进行概述则应启用两个属性hibernate.format_sqlhibernate.use_sql_comments,以通过控制台打印执行的sql代码。

这是一个好的开始,但是似乎我们需要更多信息来准确诊断性能,例如连接事件,查询返回的数据或参数绑定( 休眠显示带问号?的参数值)。 因此,我们需要另一种方法来检查生成的sqlLog4jdbc是一个jdbc驱动程序,可以记录sql / jdbc调用。 实际上, log4jdbc是代理模式的实现,它将自动加载流行的jdbc驱动程序( Oracle,Derby,MySql,PostgreSql,H2,Hsqldb等),拦截调用,记录信息,然后将数据发送到“ 间谍 ”驱动程序。

log4jdbc中 ,根据要监视的数据,可以使用5个记录器:

  • jdbc.sqlonly :使用绑定参数替换为绑定数据来记录执行的sql
  • jdbc.sqltiming :记录执行一条SQL所花费的时间。
  • jdbc.audit :记录除ResultSets之外的所有jdbc调用。
  • jdbc.resultset :与jdbc.audit以及ResultsSets相同。
  • jdbc.connection :记录打开和关闭连接事件。

在本文中,我们将了解如何配置log4jdbc-remix ,这是log4jdbc的分支 ,除了继承log4jdbc功能之外,还可以让我们:

  • jdbc.resultsettable :以表格式记录结果集。
  • 将其配置为数据源。
  • Maven存储库中可用(在Maven存储库中不存在log4jdbc )。

在此示例中,我们将使用由JPA Spring模板创建的项目,该项目包含两个与一对多关系相关联的实体OrderItem ,以及一个执行某些数据库操作的测试。
首先要做的是将log4jdb-remixslf4j-log4j12依赖项添加到项目中:

<dependency><groupId>org.slf4j<groupId><artifactId>slf4j-log4j12<artifactId><version>1.6.4<version><dependency><dependency><groupId>org.lazyluke<groupId><artifactId>log4jdbc-remix<artifactId><version>0.2.7<version><dependency>

接下来要做的是配置活动记录器。 根据我们要监视的数据,我们激活所需的记录器。 作为示例,让我们配置log4j.xml,以便以表格式打印结果集,并显示执行每个查询所花费的时间。

<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE log4j:configuration SYSTEM 'log4j.dtd'><log4j:configuration xmlns:log4j='http:jakarta.apache.orglog4j'><appender name='console-log4jdbc' class='org.apache.log4j.ConsoleAppender'><param name='Target' value='System.out' ><layout class='org.apache.log4j.PatternLayout'><param name='ConversionPattern' value='%m%n' ><layout><appender><!--  <logger name='jdbc.sqlonly' additivity='false'> --><!--   <level value='debug' > --><!--   <appender-ref ref='console-log4jdbc' > --><!--  <logger> --><logger name='jdbc.sqltiming' additivity='false'><level value='info' ><appender-ref ref='console-log4jdbc' ><logger><!--  <logger name='jdbc.connection' additivity='false'> --><!--   <level value='info' > --><!--   <appender-ref ref='console-log4jdbc' > --><!--  <logger> --><!-- log4jdbc option log the jdbc results as a table --><logger name='jdbc.resultsettable' additivity='false'><level value='info' ><appender-ref ref='console-log4jdbc' ><logger><log4j:configuration>

配置记录器后,运行测试并检查输出

create table Item (id bigint generated by default as identity, price double not null, product varchar(255), quantity integer not null, order_id bigint, primary key (id))  {executed in 10 msec}create table T_ORDER (id bigint generated by default as identity, customer varchar(255), primary key (id))  {executed in 1 msec}alter table Item add constraint FK22EF339F325255 foreign key (order_id) references T_ORDER {executed in 11 msec}insert into T_ORDER (id, customer) values (null, NULL)  {executed in 1 msec}insert into Item (id, order_id, price, product, quantity) values (null, NULL, 0.0, NULL, 0) {executed in 0 msec}batching 1 statements: 0: update Item set ORDER_ID=1 where id=1  {executed in 2 msec}insert into T_ORDER (id, customer) values (null, NULL)  {executed in 0 msec}insert into Item (id, order_id, price, product, quantity) values (null, NULL, 0.0, NULL, 0) {executed in 0 msec}batching 1 statements: 0: update Item set ORDER_ID=2 where id=2  {executed in 0 msec}select order0_.id as id1_0_, order0_.customer as customer1_0_ from T_ORDER order0_ where order0_.id=2 {executed in 0 msec}|---------|---------||ID       |CUSTOMER ||---------|---------||[unread] |null     ||---------|---------|select items0_.ORDER_ID as ORDER5_1_2_, items0_.id as id2_, items0_.id as id0_1_, items0_.order_id as order5_0_1_, items0_.price as price0_1_, items0_.product as product0_1_, items0_.quantity as quantity0_1_, order1_.id as id1_0_, order1_.customer as customer1_0_ from Item items0_ left outer join T_ORDER order1_ on items0_.order_id=order1_.id where items0_.ORDER_ID=2  {executed in 0 msec}|---------|---|---|---------|------|--------|---------|---|---------||ORDER_ID |ID |ID |ORDER_ID |PRICE |PRODUCT |QUANTITY |ID |CUSTOMER ||---------|---|---|---------|------|--------|---------|---|---------||2        |2  |2  |2        |0.0   |null    |0        |2  |[unread] ||---------|---|---|---------|------|--------|---------|---|---------|insert into T_ORDER (id, customer) values (null, NULL)  {executed in 0 msec}insert into Item (id, order_id, price, product, quantity) values (null, NULL, 0.0, 'foo', 0) {executed in 0 msec}batching 1 statements: 0: update Item set ORDER_ID=3 where id=3  {executed in 0 msec}select order0_.id as id1_, order0_.customer as customer1_ from T_ORDER order0_ inner join Item items1_ on order0_.id=items1_.ORDER_ID where items1_.product='foo' limit 2  {executed in 6 msec}|---|---------||ID |CUSTOMER ||---|---------||3  |null     ||---|---------|select items0_.ORDER_ID as ORDER5_1_2_, items0_.id as id2_, items0_.id as id0_1_, items0_.order_id as order5_0_1_, items0_.price as price0_1_, items0_.product as product0_1_, items0_.quantity as quantity0_1_, order1_.id as id1_0_, order1_.customer as customer1_0_ from Item items0_ left outer join T_ORDER order1_ on items0_.order_id=order1_.id where items0_.ORDER_ID=3  {executed in 0 msec}|---------|---|---|---------|------|--------|---------|---|---------||ORDER_ID |ID |ID |ORDER_ID |PRICE |PRODUCT |QUANTITY |ID |CUSTOMER ||---------|---|---|---------|------|--------|---------|---|---------||3        |3  |3  |3        |0.0   |foo     |0        |3  |[unread] ||---------|---|---|---------|------|--------|---------|---|---------|

输出以一种时尚的格式打印,查询包含绑定参数(不是问号(?)),并且还通知了处理时间。

请注意,记录或多或少的信息仅是配置日志的问题。 此外,根据日志级别,将在每种情况下提供或多或少的信息。 如果在DEBUG中配置了logger,则将包括执行该sql的类名和行号(如果有)。 在INFO中将仅包含sql ,最后包含ERROR ,如果发生任何SQLException则显示堆栈跟踪。

优化休眠应用程序可能意味着接触到应用程序的许多部分( JVM配置,数据库引擎,网络等),但是要注意的一个非常重要的方面是发送到RDBMS的查询的数量(例如N + 1问题),以及从数据库中检索到的数据量(投影问题)和log4jdbc-remix完全适合于此目的。

作为最后一点,log4jdbc( - 混音 )是一个JDBC记录,所以没有必要只在Hibernate应用程序使用,可以与任何框架一起使用,使用一个数据源

希望该库对您有所帮助。

保持学习,

下载代码

参考:在One Jar To Rulem All博客中,我们的JCG合作伙伴 Alex Soto 使用Log4jdbc记录了JDBC操作 。

翻译自: https://www.javacodegeeks.com/2012/05/log-jdbc-operations-with-log4jdbc.html

使用Log4jdbc记录JDBC操作相关推荐

  1. jdbc:log4jdbc_使用Log4jdbc记录JDBC操作

    jdbc:log4jdbc 当我们开发任何应用程序,完成它或结束其任何模块时,我们都会开始优化过程. 大多数应用程序都包含数据库访问权限,如果您使用的是ORM ,则可能会使用hibernate . 优 ...

  2. JDBC操作数据库实例

    返回目录:<学生信息管理系统(Java+JSP)> 这里以JDBC操作MySQL数据库为例. 假设有一个名为test的数据库,里面有一张学生表,表名称为student,表结构如下: stu ...

  3. Spring中的JDBC操作

    一.Spring模板JdbcTemplate 为了使 JDBC 更加易于使用, Spring 在 JDBC API 上定义了一个抽象层, 以此建立一个 JDBC 存取框架JdbcTemplate. 作 ...

  4. Java使用Jdbc操作MySql数据库(一)

    这个示例是Java操作MySql的基本方法. 在这个示例之前,要安装好MySql,并且配置好账户密码,创建一个logininfo数据库,在数据库中创建userinfo数据表.并且在表中添加示例数据. ...

  5. JavaWeb:用JDBC操作数据库

    JDBC系列阅读 JavaWeb:用JDBC操作数据库 JavaWeb:JDBC之事务 JavaWeb:JDBC之数据库连接池 使用JDBC实现水果超市管理系统 1. 什么是JDBC JDBC的全称是 ...

  6. 使用log4jdbc记录SQL信息

    一.log4jdbc的简单介绍 使用log4jdbc在不改变原有代码的情况下,就可以收集执行的SQL文和JDBC执行情况. 平时开发使用的ibatis,hibernate,spring jdbc的sq ...

  7. JDBC操作步骤及数据库连接操作

    2019独角兽企业重金招聘Python工程师标准>>> 一.JDBC操作步骤 1.加载数据库驱动程序:各个数据库都会提供JDBC的驱动程序开发包,直接把JDBC操作所需要的开发包(一 ...

  8. 26、jdbc操作数据库(3)

    1.结果集的元数据操作 ResultSetMetaData 是描述ResultSet的元数据对象,可以通过元数据对象获取结果集的列信息,使用方式如下: public void query() {Con ...

  9. Mybatis介绍、jdbc操作数据库原始写法以及Mybatis架构

    文章目录 Mybatis介绍 jdbc操作数据库原生写法 使用jdbc编程问题总结 Mybatis架构 Mybatis介绍 MyBatis 本是apache的一个开源项目iBatis, 2010年这个 ...

最新文章

  1. n个素数构成等差数列
  2. 参加软件测试培训前景怎么样
  3. OOM?教你如何在PyTorch更高效地利用显存
  4. linux centos7 root密码重置方法
  5. 关于我对于写博客写文章的理解
  6. 找出数组中不重复的值php_PHP找出数组中不重复出现的值
  7. 特征筛选1——根据方差筛选(单变量筛选)
  8. 腾讯视频发布互动视频技术标准 爱奇艺、B站等均已布局
  9. C语言:采用交互式方式打开指定的文件,若文件打开成功,则显示该文件的大小,并显示文件内容,若文件打开失败,则提示出错信息
  10. win7开机有画面进系统黑屏怎么办
  11. fanuc换刀宏程序详解_FANUC宏程序使用举例
  12. C#开发WPF/Silverlight动画及游戏系列教程(Game Tutorial):(四十八) 落雷!治疗!陷阱!连锁闪电!多段群伤!魔法之终极五重奏①...
  13. 如何做到在子线程更新 UI?
  14. Nacos入门之服务注册中心以及命名空间分组和DataID三者关系
  15. 用ps做个一寸的照片
  16. css3 3d头像,创意css3头像展示_觉唯设计
  17. win7删除Guest和administrator内置账户及账户所属文件
  18. 从哪里租vps远程桌面服务器,vps远程桌面服务器租一个
  19. 【数字信号】基于matlab GUI DTMF双音多频信号仿真演示系统(戈泽尔算法)【含Matlab源码 016期】
  20. 最新emoji表情代码大全_周六最美早晨好问候语图片大全 早晨好图片祝福 最新早上好问候动态表情图片...

热门文章

  1. spock 集成测试_使用Spock 1.2简化对遗留应用程序的集成测试
  2. 使用实例工厂方法实例化_一些工厂实例
  3. java端到端_Java应用程序性能监控:复杂分布式应用程序的端到端性能
  4. primefaces_使用WildFly 8.2.0.Final,Primefaces 5.1和MySQL 5的JDBC领域和基于表单的身份验证...
  5. perl大骆驼和小骆驼_快速的骆驼和云消息传递
  6. openshift学习_在OpenShift上将JMS与JBoss A-MQ结合使用。 学习了有关远程客户端和加密的经验。...
  7. 那是两个小时我不会回来
  8. 休眠面试问答-最终清单
  9. 混合云的承诺,收益和产品
  10. JDK 11:Java序列化的终结开始了吗?