Java链接Oracle database小结

利用jdbc链接Oracle数据库,首先得选对jdbc的版本。html

jdk6须要ojdbc6.jar这个包。若是选错的话,调用isValid()这个方法时,有可能有这个异常:java

Exception in thread "Thread-5" java.lang.AbstractMethodError: oracle.jdbc.driver.T4CConnection.isValid(I)Z

 

选对之后,url也要设置得对:sql

database.url=jdbc:oracle:thin:@192.168.26.3:1521:yourservicename

第一,若是数据库在本机上,ip也不可以是localhost,不然的话会抛出这个异常:数据库

the network adapter could not establish the connection

第二,最后的YourServiceName必定要和NetManager里面的Naming同样(数据库sid)oracle

 

接下来,转一个示例代码:性能

 

/**
 * 一个很是标准的链接Oracle数据库的示例代码
 */
public void testOracle()
{
    Connection con = null;// 建立一个数据库链接
    PreparedStatement pre = null;// 建立预编译语句对象,通常都是用这个而不用Statement
    ResultSet result = null;// 建立一个结果集对象
    try
    {
        Class.forName("oracle.jdbc.driver.OracleDriver");// 加载Oracle驱动程序
        System.out.println("开始尝试链接数据库!");
        String url = "jdbc:oracle:" + "thin:@127.0.0.1:1521:XE";// 127.0.0.1是本机地址,XE是精简版Oracle的默认数据库名
        String user = "system";// 用户名,系统默认的帐户名
        String password = "147";// 你安装时选设置的密码
        con = DriverManager.getConnection(url, user, password);// 获取链接
        System.out.println("链接成功!");
        String sql = "select * from student where name=?";// 预编译语句,“?”表明参数
        pre = con.prepareStatement(sql);// 实例化预编译语句
        pre.setString(1, "刘显安");// 设置参数,前面的1表示参数的索引,而不是表中列名的索引
        result = pre.executeQuery();// 执行查询,注意括号中不须要再加参数
        while (result.next())
            // 当结果集不为空时
            System.out.println("学号:" + result.getInt("id") + "姓名:"
                    + result.getString("name"));
    }
    catch (Exception e)
    {
        e.printStackTrace();
    }
    finally
    {
        try
        {
            // 逐一将上面的几个对象关闭,由于不关闭的话会影响性能、而且占用资源
            // 注意关闭的顺序,最后使用的最早关闭
            if (result != null)
                result.close();
            if (pre != null)
                pre.close();
            if (con != null)
                con.close();
            System.out.println("数据库链接已关闭!");
        }
        catch (Exception e)
        {
            e.printStackTrace();
        }
    }
}

 

本文完url

相关文章
相关标签/搜索