我有一个具有 java.sql.Connection 的超类。有很多子类使用连接来执行选择。
我需要拦截通过连接执行的所有语句,并记录执行的 SQL。
我该怎么做?
使用log4jdbc。它是一个代理 JDBC 驱动程序,它记录您的所有 SQL 并将 SQL 和参数传递给底层驱动程序。这样,您的代码甚至不必知道日志记录,它们都包含在第三方库中。
配置主要包括更改 JDBC 连接字符串以使用代理而不是真正的驱动程序,并告诉 log4jdbc 真正的 JDBC 驱动程序是什么。然后你在你的 log4j 配置中选择日志类别来告诉你想要记录什么样的东西。您可以获取 SQL、计时信息、连接打开和关闭事件以及结果集内容。
如果您想深入了解它的工作原理,请参阅 Jack Shirazi 的书Java Performance Tuning。在 JDBC 章节中有一个构建代理驱动程序的扩展示例。