java用jdbc.thin模式连接远程Oracle数据库报错,请教原因.

在客服端主机上运行一个java程序,此程序访问安装在另一台主机上的Oracle数据库.但是报错:"IO Error: The Network Adapter could not establish the connection".

以下是java程序的代码:
##############################################################
import java.sql.*;
import oracle.jdbc.pool.OracleDataSource;

public class mytest01 {

public static void main(String[] arg) {
    (new mytest01()).launch();
}

public void launch() {
    Statement stmt = null;
    ResultSet rset = null;

    try {
        OracleDataSource ds = new OracleDataSource();
        ds.setURL("jdbc:oracle:thin:@192.168.17.3:1521:vpos");
        Connection conn = ds.getConnection("hr","hrhr");
        stmt = conn.createStatement();
        rset = stmt.executeQuery("SELECT * FROM my_table");

        while (rset.next()) {
            System.out.println(rset.getString(2));
        }
    } catch (SQLException ex) {
        ..... //捕捉异常的代码省略掉.
    }
}

}
##############################################################
192.168.17.3是Oracle服务器的IP,vpos是SID,hr是用户,hrhr是密码.

运行java程序的主机(IP 192.168.17.4)与服务器之间的连接没有问题.请问为什么会这样报错?

另外还发现,如果将这个程序放到Oracle服务器上运行是没有问题的.

1个回答

1) 首先通过手工确认,客户端主机能够连接到ORACEL服务器,使用SQLPLUS测试一下。
2) 使用标准的JAVA JDBC方式连接测试一下。http://zhidao.baidu.com/question/100531503.html

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问