连接oracle数据库的各种oracle jdbc驱动程序的细节。
这些细节包括:
1、导入jdbc包
2、注册oracle jdbc驱动程序
3、打开数据库连接
4、执行sql dml语句在数据库表中获取、添加、修改和删除行
一、jdbc驱动程序
共有有4种
1、thin驱动程序
thin驱动程序是所有驱动程序中资源消耗最小的,而且完全用java编写的。
该驱动程序只使用tcp/ip且要求oracle net。被称为第4类驱动程序。
它使用ttc协议与oracle数据库进行通信。能够在applet、application中使用。
2、oci驱动程序
oci驱动比thin需要资源要多,但性能通常好一点。oci驱动适合于部署在
中间层的软件,如web服务器。不能在applet中使用oci驱动。是第2类驱动程序。
不完全用java写的,还包含了c代码。该驱动有许多附加的性能增强特性,
包括高级的连接缓冲功能。
注意:oci驱动要求在客户计算机上安装它。
3、服务器内部驱动程序
服务器内部驱动程序提供对数据库的直接访问,oracle jvm使用它与数据库进行通信。
oracle jvm是与数据库集成的java virtual machine,可以使用oracle jvm将
java类装载进数据库,然后公布和运行这个类中包含的方法。
4、服务器thin驱动程序
服务器端thin驱动程序也是由oracle jvm使用的,它提供对远程数据库的访问。
也是完全用java编写的。
二、导入jdbc包
三、注册oracle jdbc驱动程序
必须先向java程序注册oracle jdbc驱动程序,然后才能打开数据库连接。
有两种注册oracle jdbc驱动程序的办法。
1、使用java.lang.class的forname()方法
例子:class.forname(oracle.jdbc.oracledriver);
2、使用jdbc drivermanager类的registerdriver()方法。
例子:drivermanager.registerdriver(new oracle.jdbc.oracledriver());
如果使用oracle8i jdbc驱动程序,那么需要导入oracle.jdbc.driver.oracledriver类,
然后注册这个类的实例。
例子:
import oracle.jdbc.driver.oracledriver;
drivermanager.registerdriver(new oracle.jdbc.oracledriver());
注意:从jdbc2.0开始,只用jdbc驱动程序的更标准办法是通过数据源。
四、打开数据库连接
必须先打开数据库连接,然后才能在java程序中执行sql语句。打开数据库连接
的主要办法。
1、drivermanager类的getconnection()方法。
drivermanager.getconnection(url,username,passwrod);
url:程序要连接的数据库,以及要使用的jdbc驱动程序
url的结构依赖于jdbc驱动程序的生产商。对于oracle jdbc驱动程序,数据库url的结构:
driver_name是程序使用的oracle jdbc驱动程序的名称。如:
jdbc:oracle:thin oracle jdbc thin驱动程序
jdbc:oracle:oci oracle jdbc oci驱动程序
jdbc:oracle:oci8 oracle jdbc oci驱动程序
driver_information是连接数据库所需的驱动程序特有的信息。这依赖于使用的驱动程序。
对于oracle jdbc thin驱动程序,可以用
host_name:port:database_sid 或者 oracle net关键字-值对
(description=(address=(host=host_name)(protocol=tcp)(port=port()
(connect_data=(sid=database_sid)))
host_name: 运行数据库的机器的名称
port: net数据库监听器等待这个端口上的请求,默认是1521
database_sid: 要连接的数据库实例的oracle sid。
username: 程序连接数据库时使用的数据库用户名
passwrod: 用户名的口令
例子:
connection myconnection=drivermanager.getconnection(
jdbc:oracle:thin:@localhost:1521:orcl,
store_user,
store_password);
connection myconnection=drivermanager.getconnection(
jdbc:oracle:oci:@(description=(address=(host=localhost)
(protocol=tcp)(port=1521))(connect_data=(sid=orcl))),
store_user,
store_password);
2、使用oracle数据源对象,必须先创建这个对象,然后连接它。使用这种方法
采用了一种设置数据库连接信息的标准化方式,oracle数据源对象可以与
java naming and directory interface(java名字与目录接口,jndi)一起使用。