`
liuxinglanyue
  • 浏览: 562627 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

分析各种Oracle JDBC驱动程序的细节

阅读更多

连接Oracle数据库的各种oracle JDBC驱动程序的细节。 

这些细节包括: 

1、导入JDBC包 

2、注册oracle JDBC驱动程序 

3、打开数据库连接 

4、执行SQL DML语句在数据库表中获取、添加、修改和删除行 

一、Oracle 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类, 

然后注册这个类的实例。 

例子: 

   1. import oracle.jdbc.driver.OracleDriver;  
   2. 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: 用户名的口令 

例子: 

   1. Connection myConnection=DriverManager.getConnection(  
   2. "jdbc:oracle:thin:@localhost:1521:ORCL",  
   3. "store_user",  
   4. "store_password");  
   5. Connection myConnection=DriverManager.getConnection(  
   6. "jdbc:oracle:oci:@(description=(address=(host=localhost)"+  
   7. "(protocol=tcp)(port=1521))(connect_data=(sid=ORCL)))",  
   8. "store_user",  
   9. "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数据源对象 

   1. import oracle.jdbc.pool.OracleDataSource;  
   2. 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()方法。 

例子: 

   1. myDataSource.setServerName("localhost");  
   2. myDataSource.setDatabaseName("localhost");  
   3. myDataSource.setDriverType("oci");  
   4. myDataSource.setNetworkProtocol("tcp");  
   5. myDataSource.setPortNumber(1521);  
   6. myDataSource.setUser("admin");  
   7. myDataSource.setPassword("helloworld");  
   8. String serverName=myDataSource.getServerName();  
   9. 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。 

   1. select>executeQuery()  
   2. insert,update,delete>executeUpdate() 

如果预先不知道要执行SQL语句的类型,可以使用execute()方法,execute()方法也可以执行DDL语句。 

当然还有个PrepareStatement类可以用于代表JDBC(详细见另外文章)。 

一旦得到了Statement对象,就可以使用JDBC发出SQL语句了。 

六、从数据库获取数据 

使用Oracle 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类型存储。 

例子: 

   1. while(rs!=null && rs.next()){  
   2. String user=rs.getString("user");  
   3. String sysdate=rs.getString(2);  
   4. //至于Date类型,就要注意日期和时间的区别,最好使用Timestamp  
   5. java.sql.Timestamp hopeDateTemp=rsResult.getTimestamp("sysdate");  
   6. java.text.SimpleDateFormat sdf=new java.text.SimpleDateFormat("yyyyMMdd HH:mm");  
   7. String hopeDate=sdf.format(hopeDateTemp);//(这里主要是JDBC,就不详细讨论了:p)  
   8. } 

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类来做。

转:http://john521.iteye.com/blog/759231

分享到:
评论

相关推荐

    oracle jdbc驱动 ojdbc14-10.2.0.4.0.jar工具

    Oracle JDBC驱动程序,即ojdbc14-10.2.0.4.0.jar,是Oracle数据库与Java应用程序之间的重要桥梁,它允许Java开发者通过Java编程语言来访问和操作Oracle数据库。在Java环境中,JDBC(Java Database Connectivity)...

    OracleJDBC连接类

    Oracle JDBC 包含多个类和接口,其中最核心的是 `oracle.jdbc.driver.OracleDriver` 类,它是实现了 JDBC 驱动程序接口的类,负责建立到 Oracle 数据库的连接。要使用 Oracle JDBC,首先需要在项目中添加 Oracle 的 ...

    Jdbc.zip_JDBC程序_oracle_oracle jdbc

    Oracle JDBC驱动程序是Oracle公司提供的,用于使Java应用程序能够连接到Oracle数据库。这里的关键知识点包括: 1. **JDBC基本概念**:JDBC是Java API,由一组接口和类组成,用以建立、执行SQL语句和管理数据库连接...

    jdbc 源码 oracle 自带jdbc

    Oracle JDBC驱动程序是Oracle公司提供的,用于连接Java应用到Oracle数据库的桥梁。这份"jdbc源码,oracle自带jdbc"的资源对学习Java数据库开发的人员来说极其宝贵,因为它允许深入理解JDBC的工作原理以及Oracle驱动...

    oracle jdbc驱动 ojdbc14-10.2.0.4.0下载

    Oracle JDBC驱动程序是连接Java应用程序与Oracle数据库的关键组件。ojdbc14-10.2.0.4.0是Oracle公司为Java开发者提供的一款针对Oracle 10g数据库的JDBC驱动版本。这个版本的驱动是Java 1.4兼容的,因此适合那些仍...

    各种数据库的jdbc驱动

    本压缩包集合了多种常见数据库的JDBC驱动,包括MySQL、Oracle和SQL Server 2005等,这对于开发者来说是一个非常实用的资源库。 1. **JDBC概述**: JDBC是Java平台的一部分,它为开发者提供了统一的接口来访问不同...

    Java Programming with Oracle JDBC

    - Oracle JDBC驱动程序的不同版本及其对JDK的支持情况。 - 如何根据JDK版本选择合适的驱动程序。 - **3.2 Applet的生活**: - Applet应用程序的特点。 - Applet与数据库交互的挑战。 - **3.3 打包Applet**: - ...

    kettle支持oracle12c

    1. **下载JDBC驱动**:首先,你需要从Oracle官方网站下载适用于Oracle 12c的JDBC驱动程序,通常文件名为`ojdbc14.jar`、`ojdbc6.jar`或`ojdbc7.jar`等,具体取决于你的Java版本和Oracle 12c的兼容性需求。...

    sqlserver2000-jdbc2.0驱动

    `sqljdbc.jar`是微软早期发布的JDBC驱动程序,适用于Java 2 Platform, Standard Edition (J2SE) 5.0及更低版本。这个驱动程序符合JDBC 3.0规范,为SQL Server 2000提供了基础的数据访问功能。 `sqljdbc4.jar`则是较...

    Oracle ODBC 64位驱动 Ver12.1.0.2.0

    这个版本的驱动程序是Oracle数据库客户端的一个重要组成部分,允许用户在64位环境下使用各种支持ODBC的应用程序与Oracle数据库进行交互。 ODBC是一种标准的数据访问接口,由Microsoft开发,使得应用程序能够访问...

    Oracle、MySQL、SQL Server 2000调用JDBC驱动的方法

    为了能够使用Java应用程序连接Oracle数据库,首先需要在项目中添加Oracle的JDBC驱动包`ojdbc14.jar`。该驱动包包含了Java应用程序与Oracle数据库通信所需的所有类和接口。 **步骤如下:** 1. **加载JDBC驱动:** ...

    高性能 Oracle JDBC 编程

    要充分运用UCP和语句池,开发者需要正确设置开发环境,包括安装JDK 1.6及以上版本、支持JDK 1.6的Oracle JDBC瘦驱动程序,以及Oracle通用连接池库(UCP)。此外,还需熟悉UCP的配置参数,如最大连接数、最小连接数等...

    JDBC sql2000,2005,mysql,oracle驱动包.zip

    Microsoft提供了适用于Java的JDBC驱动程序,称为"Microsoft JDBC Driver",用于与SQL Server数据库通信。这个驱动包包括了Type 4 JDBC驱动,它是一种纯Java实现,不需要数据库供应商提供的本地库。驱动包可能包含...

    JDBC所有驱动程序

    JDBC驱动程序是实现这些接口的Java代码,它允许Java应用程序与不同类型的数据库进行通信。在Java中,JDBC驱动被分为四种类型: 1. **类型1:JDBC-ODBC桥接驱动** - 这是最古老的驱动方式,它依赖于本地系统上的ODBC...

    JDBC Driver(内附MS SQL Server、Oracle、MySQL的驱动)

    本资源包含针对三个主流关系型数据库管理系统——Microsoft SQL Server、Oracle和MySQL的JDBC驱动程序,这将极大地简化Java开发者的工作。 1. **Microsoft SQL Server JDBC Driver**:Microsoft SQL Server是一款由...

    orai18n.jar oracle 驱动程序(java&da转换)

    这个JAR文件包含了Oracle JDBC驱动程序的一部分,特别关注于国际化(i18n)的支持,因此名为"orai18n",其中"18"代表英文单词"international"的首两个字母。它主要处理与日期、时间、货币格式等相关的本地化问题,...

    jdbc_on_oracle

    Oracle提供了自己的JDBC驱动程序,即Oracle JDBC驱动,这使得Java应用程序能够与Oracle数据库进行通信,实现数据的查询、更新、插入和删除等操作。 ### 《Expert Oracle JDBC Programming》一书概述 由R.M. Menon...

    mysql-oracle-sql-jdbc驱动

    总的来说,"mysql-oracle-sql-jdbc驱动"这个资源集合了三大主流数据库的JDBC驱动,极大地简化了Java开发者在数据库操作中的准备工作,使得他们可以专注于应用程序的逻辑开发,而不用花费额外的时间寻找和配置驱动。...

    oracle jdbc pdf

    Oracle JDBC驱动是Oracle官方提供的用于连接Oracle数据库的JDBC驱动程序。它允许Java应用程序通过标准JDBC API与Oracle数据库进行交互。该驱动支持多种特性,包括高性能的数据传输、高级功能的支持(如存储过程调用...

    sqlserver,mysql,oracle数据库连接驱动

    JDBC驱动适用于Java应用程序,ODBC驱动则适用于任何支持ODBC的平台,而Oracle Instant Client是一个轻量级的客户端,包含了连接Oracle数据库所需的必要组件,降低了客户端的安装需求。 数据库驱动的工作原理: ...

Global site tag (gtag.js) - Google Analytics