gpt4 book ai didi

java - 拦截 JDBC 连接

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:02:31 25 4
gpt4 key购买 nike

我有一个具有 java.sql.Connection 的父类(super class)。有很多子类使用连接来执行选择。

我需要拦截所有通过连接执行的语句,并记录执行的SQL。

我该怎么做?

最佳答案

使用log4jdbc .它是一个代理 JDBC 驱动程序,记录所有 SQL 并将 SQL 和参数传递给底层驱动程序。这样您的代码甚至不必知道日志记录,它都包含在第三方库中。

配置主要包括更改 JDBC 连接字符串以使用代理而不是真正的驱动程序,并告诉 log4jdbc 真正的 JDBC 驱动程序是什么。然后你在你的 log4j 配置中选择日志记录类别来告诉你想要记录什么样的事情。您可以获取SQL、时序信息、连接打开和关闭事件以及结果集内容。

如果您想深入了解它的工作原理,请参阅 Jack Shirazi 的书 Java Performance Tuning。在关于 JDBC 的章节中有一个构建代理驱动程序的扩展示例。

关于java - 拦截 JDBC 连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15977648/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com