为 JDBC 连接设置网络超时

2022-09-02 20:55:27

我正在尝试在 Java 中设置网络超时我的 Oracle 数据库连接。但是,我收到错误。下面是示例代码及其各自的异常。

try{
    conn = new Database("oracle").connect();
    conn.setNetworkTimeout(null, 30000); //I don't have an Executor, so the field is set to null
    System.out.println(Switch.date() + " -> Database Connection Initialized");
}
catch(SQLException ex){
    Logger.getLogger(Switch.class.getName()).log(Level.SEVERE, null, ex);
}

我得到的例外是:

Exception in thread "main" java.lang.AbstractMethodError:oracle.jdbc.driver.T4CConnection.setNetworkTimeout(Ljava/util/concurrent/Executor;I)V
   at ke.co.smart.Switch.<init>(Switch.java:524)
   at ke.co.smart.Switch.main(Switch.java:161)
Java Result: 1

我相信这与抽象的方法有关(阅读抽象方法错误)。可能导致此错误的原因是什么,因为我只实现了我认为已经在Java中定义的方法,因此不会拒绝编译。

注意:如果有抽象方法,Java不允许编译具体的类。


答案 1

setNetworkTimeout()在 JDBC 4.1 中引入,在 JDBC 4.0 中不存在。

你会想要ojdbc7,因为如果你想使用方法,JDBC 4.1只附带Java 7。setNetworkTimeout()

根本问题是,在以后的规范中向接口添加方法可能会导致这些接口的旧实现因错误而中断。即将推出的Java 8的新功能之一,默认方法,有望使这个问题稍微不那么成问题。


显然,Oracle 还有一个 JDBC 驱动程序属性可以修改套接字超时。

如果您使用的是精简驱动程序,您还可以尝试使用此 Oracle JDBC 属性来设置套接字超时:

Properties props = new Properties();
props.setProperty("user", "dbuser");
props.setProperty("password", "dbpassword");
props.setProperty(OracleConnection.CONNECTION_PROPERTY_THIN_NET_CONNECT_TIMEOUT, "2000");

Connection con = DriverManager.getConnection("<JDBC connection string>", props);

答案 2

这是软件演进的经典案例。JDBC 提供程序尚未在您正在使用的 jar 中给出该方法的实现。看起来您的JDBC库很旧,您可以尝试最新的库。

从这里下载最新的一个: http://www.oracle.com/technetwork/database/enterprise-edition/jdbc-112010-090769.html

试试从这里采取的这种方法

conn.setNetworkTimeout(Executors.newFixedThreadPool(numThreads), yourTimeout);

推荐