JDBC体系结构
l
JDBC
接口(
API
)包括两个层次:
Ø
面向应用的
API
:
JavaAPI
,抽象接口,供应用程序开发人员使用(连接数据库,执行
SQL
语句,获得结果)。
Ø
面向数据库的
API
:
JavaDriver API
,供开发商开发数据库驱动程序用。
JDBC是sun公司提供一套用于数据库操作的接口,java程序员只需要面向这套接口编程即可。不同的数据库厂商,需要针对这套接口,提供不同实现。不同的实现的集合,即为不同数据库的驱动。————面向接口编程。
JDBC驱动程序分类
l
JDBC
驱动程序:各个数据库厂商根据
JDBC
的规范制作的
JDBC
实现类的类库
l
JDBC
驱动程序总共有四种类型:
Ø
第一类:
JDBC-ODBC
桥。
Ø
第二类:部分本地
API
部分
Java
的驱动程序。
Ø
第三类:
JDBC
网络纯
Java
驱动程序。
Ø
第四类:本地协议的纯
Java
驱动程序
。
Ø
第三、四两类都是纯
Java
的驱动程序,因此,对于
Java
开发者来说,它们在性能、可移植性、功能等方面都有优势。
第一类:ODBC
l
早期对数据库的访问,都是调用数据库厂商提供的专有的
API
。为了在
Windows
平台
下提供统一的访问方式,微软推出了
ODBC(Open Database Connectivity
,开放式数据库连接
)
,并提供了
ODBCAPI
,使用者在程序中只需要调用
ODBCAPI
,由
ODBC
驱动程序将调用转换成为对特定的数据库的调用请求。
l
一个基于
ODBC
的应用程序对数据库的操作不依赖任何
DBMS(databasemanager system)
,不直接与
DBMS
打交道,所有的数据库操作由对应的
DBMS
的
ODBC
驱动程序
完成。也就是说,不论是
FoxPro
、
Access, MYSQL
还是
Oracle
数据库,均可用
ODBCAPI
进行访问。由此可见,
ODBC
的最大优点是能以统一的方式处理所有的数据库
。
JDBC-ODBC桥
l
JDBC-ODBC
桥本身也是一个驱动,利用这个驱动,可以使用
JDBC-API
通过
ODBC
去访问数据库。这种机制实际上是把标准的
JDBC
调用转换成相应的
ODBC
调用,并通过
ODBC
访问数据库
l
因为需要通过多层调用,所以利用
JDBC-ODBC
桥访问数据库的效率较低
l
在
JDK
中,提供了
JDBC-ODBC
桥的实现类
(
sun.jdbc.odbc.JdbcOdbcDriver
)
第二类:部分本地API部分Java的驱动程序
l
这种类型的
JDBC
驱动程序使用
Java
编写,它调用数据库厂商提供的本地
API
l
通过这种类型的
JDBC
驱动程序访问数据库减少了
ODBC
的调用环节,提高了数据库访问的效率
l
在这种方式下需要在客户的机器上安装本地
JDBC
驱动程序和特定厂商的本地
API
第三类:JDBC网络纯Java驱动程序
l
这种驱动利用中间件的应用服务器来访问数据库。应用服务器作为一个到多个数据库的网关,客户端通过它可以连接到不同的数据库服务器。
l
应用服务器通常有自己的网络协议,
Java
用户程序通过
JDBC
驱动程序将
JDBC
调用发送给应用服务器,应用服务器使用本地程序驱动访问数据库,从而完成请求。
第四类:本地协议的纯 Java驱动程序
多数数据库厂商已经支持允许客户程序通过网络直接与数据库通信的网络协议。
这种类型的驱动程序完全使用Java 编写,通过与数据库建立的Socket 连接,采用具体与厂商的网络协议把JDBC 调用转换为直接连接的网络调用
JDBC API
l
JDBC API
是一系列的接口,它使得应用程序能够进行数据库联接,执行
SQL
语句,并且得到返回结果。