4

我需要在我的 Java EE 应用程序中记录 SQL 执行时间(任何进一步的统计数据都是可选的)。

事情以一种更不标准的方式设置:应用程序服务器上的数据源为池化 JDBC 连接提供服务。

应用程序用于 DB 访问组合:

  • 休眠和
  • Spring JDBC模板

它运行在:

  • Glassfish OSE 和
  • 甲骨文星展银行

我知道:有什么比 P6Spy 更好的吗?但是,从我的角度来看,问题/答案已经过时了。

到目前为止我发现了什么:

非常欢迎基于经验的建议。

请注意,我对这样的答案很感兴趣:我们正在使用 XYZ,这是我们的经验,而不是我刚刚在谷歌上搜索并感觉......

4

3 回答 3

2

如果您想要准确的 SQL 执行时间,那么最好的选择是 sql trace。但是你想把它放在你的 Java EE 应用程序中,所以显然需要一个准确的执行时间。

以下是我建议的事情[我已经在我的代码中实现了它们]:

  1. 如果您只是希望它用于登录目的,那么有适当的 Log4j 调试消息将打印时间以及日志条目。

  2. 我为我的应用程序实现了一个 BatchLog 表,用于记录操作的开始和结束时间。因此,在您的情况下,它将是您查询的开始和结束时间。现在,如果它只是一个查询,那么触发器可能会在这里有所帮助,否则您可以在运行查询之前和之后更新日志表。或者更好的是一个存储过程,它可以处理整个事情并提供更准确的数据。

于 2013-08-17T13:52:01.563 回答
1

测量时间并记录它似乎是 AOP 的工作。如果您使用 EJB,一个简单的拦截器应该可以解决您的问题(例如http://www.javacodegeeks.com/2013/07/java-ee-ejb-interceptors-tutorial-and-example.html)。如果是 Spring(从 JDBCTemplate 判断),请尝试 Aspectj。

于 2013-08-16T10:18:58.643 回答
0

好的,非常感谢您的回答。最后,我决定选择 P6Spy,它带有特定于我们场景的补丁。

此外,由于我相信 P6spy 正在填补的空白这些天仍然存在,所以我决定参与它的开发(https://github.com/p6spy/p6spy)。随时将您的问题或功能请求报告至:https ://github.com/p6spy/p6spy/issues以使其满足您的需求。

于 2013-08-30T05:26:00.917 回答