gpt4 book ai didi

java - JDBC 记录到文件

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

我需要将项目中对 Oracle 数据库的所有查询记录到日志文件中。

实现此目标的好的解决方案是什么?一些示例用法将不胜感激。

我看过SLF4Jjdbcdslog ,但我不确定如何使用它登录文件。此外,我需要“过滤”一些日志(因为我不需要知道某些 getxxxx 方法何时被调用)

我更喜欢使用 java.util.logging 但这不是必需的。

谢谢。

** 更新 **

我找到了 this Oracle article ,但是它并没有真正说明如何以编程方式做同样的事情。

最佳答案

经过大量阅读,这就是我的工作方式:


注意:有关更多信息,请阅读 Oracle Diagnosability in JDBC文档


Properties prop = new Properties();
prop.put ("user", USER);
prop.put ("password", PASS);
// prop.put(propname, propValue);

Class.forName("oracle.jdbc.driver.OracleDriver");

enableLogging(false);

conn = DriverManager.getConnection("jdbc:oracle:thin:@"+HOST+":"+PORT+":"+SID, prop);

这就是魔法:

static private void enableLogging(boolean logDriver) 
throws MalformedObjectNameException, NullPointerException,
AttributeNotFoundException, InstanceNotFoundException,
MBeanException, ReflectionException, InvalidAttributeValueException,
SecurityException, FileNotFoundException, IOException
{
oracle.jdbc.driver.OracleLog.setTrace(true);

// compute the ObjectName
String loader = Thread.currentThread().getContextClassLoader().toString().replaceAll("[,=:\"]+", "");
javax.management.ObjectName name = new javax.management.ObjectName("com.oracle.jdbc:type=diagnosability,name="+loader);

// get the MBean server
javax.management.MBeanServer mbs = java.lang.management.ManagementFactory.getPlatformMBeanServer();

// find out if logging is enabled or not
System.out.println("LoggingEnabled = " + mbs.getAttribute(name, "LoggingEnabled"));

// enable logging
mbs.setAttribute(name, new javax.management.Attribute("LoggingEnabled", true));

File propFile = new File("path/to/properties");
LogManager logManager = LogManager.getLogManager();
logManager.readConfiguration(new FileInputStream(propFile));

if (logDriver) {
DriverManager.setLogWriter(new PrintWriter(System.err));
}
}

属性文件(来自 Oracle 的文档):

.level=SEVERE
oracle.jdbc.level=INFO
oracle.jdbc.handlers=java.util.logging.ConsoleHandler
java.util.logging.ConsoleHandler.level=INFO
java.util.logging.ConsoleHandler.formatter=java.util.logging.SimpleFormatter

基本上,这是声明处理程序的地方

oracle.jdbc.handlers=java.util.logging.ConsoleHandler

声明要由 Oracle 的 JDBC 驱动程序使用的 ConsoleHandler。可以在这里声明任意数量的处理程序,每行一个,带有类的完整限定名:

oracle.jdbc.handlers=java.util.logging.ConsoleHandler
oracle.jdbc.handlers=java.util.logging.FileHandler
...

可以使用相同的规则提供自己定制的处理程序。以下几行用于设置处理程序

java.util.logging.ConsoleHandler.level=INFO

将调用 ConsoleHandler 处理程序实例的方法 setLevel(Level.INFO)

com.my.own.project.logging.handler.MyHandler.foo=Bar

将调用 MyHandler 处理程序实例的方法 setFoo("Bar")。就是这样。

登录愉快!

关于java - JDBC 记录到文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5738181/

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