ito_oti 2011-06-05 15:35
浏览 295
已采纳

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条回答 默认 最新

  • 兵锅 2011-06-05 15:52
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥50 如何用脚本实现输入法的热键设置
  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)