Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/375.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 如何在使用JDBC时启用SQL语句的日志记录_Java_Sql_Oracle_Logging_Jdbc - Fatal编程技术网

Java 如何在使用JDBC时启用SQL语句的日志记录

Java 如何在使用JDBC时启用SQL语句的日志记录,java,sql,oracle,logging,jdbc,Java,Sql,Oracle,Logging,Jdbc,我试图通过连接EclipseIDE中的Oracle数据库,使用JDBC程序启用日志 我已经看过这篇文章了 然后我创建了下面的java程序并从EclipseIDE运行它,但是我无法看到JDBC驱动程序类生成的任何日志 import java.io.File; import java.io.FileInputStream; import java.io.PrintWriter; import java.sql.Connection; import java.sql.DriverManager; im

我试图通过连接EclipseIDE中的Oracle数据库,使用JDBC程序启用日志

我已经看过这篇文章了 然后我创建了下面的java程序并从EclipseIDE运行它,但是我无法看到JDBC驱动程序类生成的任何日志

import java.io.File;
import java.io.FileInputStream;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;
import java.util.logging.LogManager;
import java.util.logging.Logger;

public class Logging {

    static Logger log = Logger.getLogger(Logging.class.toString());
    static Connection con = null;

    public static void main(String[] args) throws SQLException,
            ClassNotFoundException {
        System.setProperty("oracle.jdbc.Trace", Boolean.TRUE.toString());
        System.setProperty("java.util.logging.config.file",
                "OracleLog.properties");
        log.info("Test Message");
        enableLogging(false);
        getConnection();
        closeConnection();
    }

    static private void enableLogging(boolean logDriver) {
        try {
            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));
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static Connection getConnection() throws SQLException,
            ClassNotFoundException {
        Properties connectionProps = new Properties();
        connectionProps.put("user", "test_app");
        connectionProps.put("password", "test");

        Class.forName("oracle.jdbc.driver.OracleDriver");
        con = DriverManager.getConnection(
                "jdbc:oracle:thin:@"+HOST_IP+":1521:"+SID,
                connectionProps);
        System.out.println("Connected to database");
        return con;
    }

    public static void closeConnection() throws SQLException {
        if (con != null) {
            con.close();
        }
    }

}
我的OracleLog.properties文件中有以下内容:

.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
但当我通过将
ojdbc6-11.2.0.3.jar
放在类路径中运行程序时,我得到的异常如下:

INFO: Test Message
javax.management.InstanceNotFoundException: com.oracle.jdbc:type=diagnosability,name=sun.misc.Launcher$AppClassLoader@73d16e93
    at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getMBean(DefaultMBeanServerInterceptor.java:1095)
    at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getAttribute(DefaultMBeanServerInterceptor.java:643)
    at com.sun.jmx.mbeanserver.JmxMBeanServer.getAttribute(JmxMBeanServer.java:678)
    at myjdbc.Logging.enableLogging(Logging.java:45)
    at myjdbc.Logging.main(Logging.java:24)
Connected to database
如果类路径中有
ojdbc6_g.jar
,那么我也会得到相同的异常

请让我知道如何为我的JDBC程序启用日志记录?基本上,我希望看到由内部JDBC代码生成的日志

更新: 现在我将
ojdbc6dms.jar
文件放在类路径中,我的程序给出以下异常:

Nov 28, 2014 9:09:02 PM jdbc.chap2.Logging main
INFO: Test Message
javax.management.InstanceNotFoundException: com.oracle.jdbc:type=diagnosability,name=sun.misc.Launcher$AppClassLoader@73d16e93
    at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getMBean(DefaultMBeanServerInterceptor.java:1095)
    at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getAttribute(DefaultMBeanServerInterceptor.java:643)
    at com.sun.jmx.mbeanserver.JmxMBeanServer.getAttribute(JmxMBeanServer.java:678)
    at jdbc.chap2.Logging.enableLogging(Logging.java:45)
    at jdbc.chap2.Logging.main(Logging.java:24)
Exception in thread "main" java.lang.NoClassDefFoundError: oracle/dms/console/DMSConsole
    at oracle.jdbc.driver.DMSFactory.<clinit>(DMSFactory.java:48)
    at oracle.jdbc.driver.PhysicalConnection.createDMSSensors(PhysicalConnection.java:2121)
    at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:730)
    at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:433)
    at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:32)
    at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:608)
    at java.sql.DriverManager.getConnection(DriverManager.java:664)
    at java.sql.DriverManager.getConnection(DriverManager.java:208)
    at jdbc.chap2.Logging.getConnection(Logging.java:70)
    at jdbc.chap2.Logging.main(Logging.java:25)
Caused by: java.lang.ClassNotFoundException: oracle.dms.console.DMSConsole
    at java.net.URLClassLoader$1.run(URLClassLoader.java:372)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:360)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 10 more
2014年11月28日晚上9:09:02 jdbc.chap2.Logging main
信息:测试消息
javax.management.InstanceNotFoundException:com.oracle.jdbc:type=diagnosability,name=sun.misc.Launcher$AppClassLoader@73d16e93
位于com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getMBean(DefaultMBeanServerInterceptor.java:1095)
位于com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getAttribute(DefaultMBeanServerInterceptor.java:643)
位于com.sun.jmx.mbeanserver.JmxMBeanServer.getAttribute(JmxMBeanServer.java:678)
位于jdbc.chap2.Logging.enableLogging(Logging.java:45)
位于jdbc.chap2.Logging.main(Logging.java:24)
线程“main”java.lang.NoClassDefFoundError中出现异常:oracle/dms/console/DMSConsole
位于oracle.jdbc.driver.DMSFactory(DMSFactory.java:48)
位于oracle.jdbc.driver.PhysicalConnection.createDMSSensors(PhysicalConnection.java:2121)
位于oracle.jdbc.driver.PhysicalConnection.(PhysicalConnection.java:730)
位于oracle.jdbc.driver.T4CConnection(T4CConnection.java:433)
位于oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:32)
位于oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:608)
位于java.sql.DriverManager.getConnection(DriverManager.java:664)
位于java.sql.DriverManager.getConnection(DriverManager.java:208)
位于jdbc.chap2.Logging.getConnection(Logging.java:70)
位于jdbc.chap2.Logging.main(Logging.java:25)
原因:java.lang.ClassNotFoundException:oracle.dms.console.DMSConsole
在java.net.URLClassLoader$1.run(URLClassLoader.java:372)
在java.net.URLClassLoader$1.run(URLClassLoader.java:361)
位于java.security.AccessController.doPrivileged(本机方法)
位于java.net.URLClassLoader.findClass(URLClassLoader.java:360)
位于java.lang.ClassLoader.loadClass(ClassLoader.java:424)
位于sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
位于java.lang.ClassLoader.loadClass(ClassLoader.java:357)
... 10多

您是否尝试设置相应的系统属性?例如,对于跟踪:

System.setProperty( "oracle.jdbc.Trace", Boolean.TRUE.toString() );

(from)

2019年更新:log4jdbc自2015年以来一直未维护。似乎仍在积极维护

原始答案 有很多间谍框架可用于此目的,请检查,我觉得这是你正在寻找的

功能

  • 完全支持JDBC3和JDBC4
  • 在大多数情况下,易于配置 您只需将驱动程序类名更改为 net.sf.log4jdbc.DriverSpy并在现有的 JDBCURL,设置日志类别,就可以开始了
  • 在记录的输出中,对于准备好的语句,绑定参数是 自动插入到SQL输出中。这大大提高了效率 许多情况下的可读性和调试
  • 可以生成SQL定时信息,以帮助确定SQL语句运行所需的时间, 帮助识别运行速度过慢的语句以及 可以使用附带的工具对数据进行后处理,以生成分析 报告数据以快速识别应用程序中的慢速SQL
  • 生成SQL连接号信息以帮助识别 连接池或线程问题。与任何潜在的 JDBC驱动程序,具有JDK1.4及以上版本和SLF4J 1.x
  • 开源软件,根据业务友好的Apache 2.0许可证授权
用法

  • 将log4jdbcjar(基于JDK版本)放入应用程序的类路径中
  • 选择要使用的日志系统,支持log4j、logback、commons日志等
  • 在应用程序的配置中,将JDBC驱动程序类设置为net.sf.log4jdbc.DriverSpy。 在许多情况下,被监视的底层驱动程序将自动加载,而无需任何其他配置
  • 将jdbc:log4前置到您正在使用的正常jdbc url

    例如,如果您的正常jdbc url是 jdbc:derby://localhost:1527//db-derby-10.2.2.0-bin/databases/MyDatabase 然后将其更改为: jdbc:log4jdbc:derby://localhost:1527//db-derby-10.2.2.0-bin/databases/MyDatabase

  • 设置你的记录器

    jdbc.sqlonly:只记录SQL。在准备好的语句中执行的SQL将自动显示,其绑定参数将替换为该位置的数据绑定,以大大提高可读性。1.0

    jdbc.sqltiming:记录执行后的SQL,包括SQL执行所用时间的计时统计信息。1.0

    jdbc.audit:记录除结果集之外的所有jdbc调用。这是一个非常庞大的输出,通常不需要,除非跟踪特定的JDBC问题。1.0

    jdbc.resultset:由于对resultset对象的所有调用都记录在案,因此其容量更大。1.0

    jdbc.connection:记录连接打开和关闭事件以及转储所有打开的连接号。这对于查找连接泄漏问题非常有用


如果您使用的是Spring framew
        <dependency>
            <groupId>com.oracle.ojdbc</groupId>
            <artifactId>ojdbc8_g</artifactId>
            <version>19.3.0.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-jul</artifactId>
            <version>2.13.0</version>
        </dependency>
        <Logger name="oracle.jdbc" level="TRACE">
            <AppenderRef ref="Console"/>
        </Logger>
        <Logger name="oracle.sql" level="TRACE">
            <AppenderRef ref="Console"/>
        </Logger>