连接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@driver_information
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数据源对象,必须先创建这个对象,然后连接它,与DriverManager.getConnection方法
相比,Oracle数据源使用了一种更标准化的方式提供连接数据库所需的各种参数。
Oracle数据源对象也可以向JNDI注册(见另外一篇学习笔记http://blog.csdn.net/207/archive/2004/12/15/217518.aspx)。
要想使用Oracle数据源,有三个步骤:
A.创建oracle.jdbc.pool.OracleDataSource类的Oracle数据源对象
import oracle.jdbc.pool.OracleDataSource;
OracleDataSource myDataSource=new OracleDataSource();
B.设置Oracle数据源对象属性,oracle.jdbc.pool.OracleDataSource类实际上实现了
JDBC提供的javax.sql.DataSource接口。
Javax.sql.DataSource接口的属性
属性名
属性说明
属性类型
databaseName
数据库名
String
dataSourceName
底层数据源类的名称
String
description
数据源的说明
String
networkProtocol
用于与数据库通信的网络协议。这只用于Oracle JDBC OCI驱动程序,默认值是”TCP”
String
password
用户名的口令
String
portNumber
Oracle Net监听器等待着个端口上数据库连接请求。默认值是1521
int
derverName
数据库服务器的机器名
String
user
数据库用户名
String
oracle.jdbc.pool.OracleDataSource类还提供了另一组属性
OracleDataSource属性
属性名
属性说明
属性类型
driverType
要使用的JDBC驱动程序。如果要使用服务器内部驱动程序,那么这设置为”kprb”,而且此属性的其他设置被忽略
String
url
可以用于指定Oracle数据库URL,这可以代替设置数据库位置。
String
tnsEntry Name
可以用于指定Oracle Net TNSNAMES字符串,在使用OCI驱动程序时也可以用于指定数据库位置
String
属性的get/set方法就像javabean的get/set写法规则一样。
注意:没有getPassword()方法。
例子:
myDataSource.setServerName("localhost");
myDataSource.setDatabaseName("localhost");
myDataSource.setDriverType("oci");
myDataSource.setNetworkProtocol("tcp");
myDataSource.setPortNumber(1521);
myDataSource.setUser("admin");
myDataSource.setPassword("helloworld");
String serverName=myDataSource.getServerName();
int portNumber=myDataSource.getPortNumber();
一旦设置了OracleDatatSource对象的属性,就可以使用它连接数据库了。
C.通过Oracle数据源对象连接数据库
Connection myConnection=myDataSource.getConnection();
也可以
Connection myConnection=myDataSource.getConnection("newOne","learning");
这个写法的用户名和口令将覆盖刚才在myDataSource中设置的用户名和口令。因此将使用
用户名newOne,口令learning连接数据库。
一旦得到Connection对象,就可以使用它创建JDBC Statement对象。
五、创建JDBC Statement对象
需要创建java.sql.Statement类的JDBC Statement对象,然后才能使用JDBC发出SQL语句。
Statement对象用于表示一个SQL语句:DML语句(select,insert,update或delete)或DDL语句(create table)
Statement myStatement=myConnection.createStatement();
根据SQL语句,就使用Statement类的不同方法执行SQL。
select-------------------->executeQuery()
insert,update,delete---->executeUpdate()
如果预先不知道要执行SQL语句的类型,可以使用execute()方法,execute()方法也可以执行DDL语句。
当然还有个PrepareStatement类可以用于代表JDBC(详细见另外文章)。
一旦得到了Statement对象,就可以使用JDBC发出SQL语句了。
六、从数据库获取数据
使用JDBC执行select语句,要使用Statement对象的executeQuery(select语句)方法,因为select语句可能返回多行,
所以executeQuery()方法返回一个对象,其中存储了select语句返回的行。它是java.sql.ResultSet类的实例。
使用ResultSet对象从数据库读取行时,有三个步骤:
1、创建和填充ResultSet对象(具体ResultSet类型操作资料这里没有讨论:P)。
Resultset rs=myStatement.executeQuery("select user,sysdate from dual");
2、从Resultset对象读取列值
这里要理解Oracle和java类型的映射关系
Java与Oracle可兼容的类型映射
Oracle类型
Java类型
CHAR
String
VARCHAR2
String
DATE
java.sql.Date 日期
java.sql.Time 时间
java.sql.Timestamp 日期和时间
INTEGER
short
int
long
NUMBER
float
double
java.matn.BigDecimal
int和String类型是核心JAVA的一部分,而java.sql.Date属于JDBC,它是核心JAVA的扩展。
JDBC提供的类型没有完全覆盖Oracle使用的所有类型,就如rowid类型,就必须使用
oracle.sql.ROWID类型存储。
例子:
while(rs!=null && rs.next()){
String user=rs.getString("user");
String sysdate=rs.getString(2);
//至于Date类型,就要注意日期和时间的区别,最好使用Timestamp
java.sql.Timestamp hopeDateTemp=rsResult.getTimestamp("sysdate");
java.text.SimpleDateFormat sdf=new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm");
String hopeDate=sdf.format(hopeDateTemp);//(这里主要是JDBC,就不详细讨论了:p)
}
JDBC提供的next()方法访问ResultSet对象中的第一行,以后每次对next()方法的调用会前进到
下一行。当rs没有更多的行读取时,next()返回false;这里建议的是ResultSet只是个临时数据
集合,如果Connection断开了,ResultSet里面的数据也没有了,所以最好使用Java的变量或对象
把rs的数据复制过来。
七、关闭ResultSet对象(吃完东西抹嘴)
例子:
rs.close();
八、INSERT、UPDATE、DELETE数据库记录
上面提到过使用SQL INSERT语句向数据库插入、修改、删除记录。JDBC有两种方式:
a.使用Statement类中定义的executeUpdate()方法
b.使用PrepareStatement类中定义的execute()方法
------------------------------------------------------------------------------------------------------------------
使用OCI方式,则必须在本机安装ORACLE CLIENT,并且注册一个service name,在URL中使用这个NAME。很显然这种方式可以用于app server,但不适用于applet,甚至applicaion。这种连接方式功能比较强大,可以直接用getBinaryStream方法来存取blob字段,为oracle所推荐,但据有关测试,这种方式的速度并没有thin方式的快。
使用thin方式,其实是直接通过网络端口存取ORACLE,所以无须在本机安装ORACLE CLIENT,比较适用于thin client(从名字上也可以看出用途),如applet等。但功能上稍弱,主要是在blob字段的存取上。只能使用Oracle提供的Blob类来做。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/xmddl369/archive/2008/12/30/3656782.aspx