怎样利用JDBC连接并 *** 作Oracle数据库

怎样利用JDBC连接并 *** 作Oracle数据库,第1张

文件用:ojdbc6.jar

/**

* 一个非常标准的连接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的默认数据库的SID

        // 如果是服务名,则用String url = "jdbc:oracle:thin:@127.0.0.1:1521/ORCL

        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()

        }

    }

}

据我所知,使用jdbc连接上oracle有一种方法:

使用thin连接

由于thin驱动都是纯Java代码,并且使用TCP/IP技术通过java的Socket连接上Oracle数据库,所以thin驱动是与平台无关的,你无需安装Oracle客户端,只需要下载一个thin驱动的jar包,并且将环境变量中的CLASS_PATH变量中加入thin驱动的路径就可以了。Thin驱动虽然与平台无关,也无需安装Oracle客户端,但是有一个致命的缺陷就是性能一般,达不到如OCI方式的企业级的要求。

另外,如果一个oracle数据库对应一台主机,可以使用thin连接;如果一个oracle数据库对应四五台主机(集群服务器),使用thin时,需要把tnsnames.ora文件中的相关数据库的整个连接字符串都拷贝下来,如此才能连接上oracle集群数据库。而这种方法也是和数位同事讨论并Google了大量资料后才发现的。之前我一直以为thin不支持集群数据库的方式。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9872920.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-02
下一篇2023-05-02

发表评论

登录后才能评论

评论列表(0条)

    保存