用JDBC访问Oracle的奇怪错误

来源:互联网 发布:windows已保护你的电脑 编辑:程序博客网 时间:2024/06/05 21:13

原来一直用.NET+SQL,去年公司准备接个Oracle的项目,借这个机会想试一下JAVA怎么样,一试之下,才发现JAVA原来真的是比较“专业”

现在我把这个错误巾出来,大家看看:

我在JBuilder2005 试用版中建议了一个Application,在Init()事件中有如下代码:

Class.forName ("oracle.jdbc.driver.OracleDriver");
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:pubdb","system","manager");
Statement stmt = conn.createStatement ();
ResultSet rset = stmt.executeQuery ("select * from system.suppliers");

while (rset.next ())
System.out.println (rset.getString ("companyname"));

编译,通过,OK

但在JButton1的事件中,这个代码却死活都不运行,搞了几个小时通不过之后,我把代码改为如下方式:

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

Connection conn = null;
        String Url="jdbc:oracle:thin:@127.0.0.1:1521:"+this.jTextField1.getText() ;
        try {
            conn = DriverManager.getConnection(
                     Url, "system",
                    "manager");
        } catch (SQLException ex) {
        }
    Statement stmt = null;
    try {
        stmt = conn.createStatement();
    } catch (SQLException ex1) {
    }
    ResultSet rset = null;
    try {
        rset = stmt.executeQuery("select * from system.suppliers");
    } catch (SQLException ex2) {
    }

    try {
        while (rset.next()) {
            JOptionPane.showMessageDialog(this,rset.getString("companyname"));
        }
    } catch (SQLException ex3) {
    }

    }

竟然通过了

事后想想,可能JAVA要求程序一定要有防错功能吧

不过现在用多了觉得用JAVA其实也是不错的,重要的是它是不要钱的:-)

原创粉丝点击