在Java中,数据库存取技术可分为如下几类:
JDBC直接访问数据库
•第三方O/R工具,如Hibernate, ibatis 等
JDBC是java访问数据库的基石,其他技术都是对jdbc的封装
什么是JDBC
JDBC(Java Database Connectivity)是一个独立于特定数据库管理系统、通用的操作数据库
的
Interface
(一组
API),定义了用来访问数据库的标准Java类库,而
接口的实现有各个数据库厂商来完成
lJDBC驱动程序(jar包):数据库厂商对JDBC接口的一组实现类(jar包)
什么是ODBC(了解)
l
ODBC(Open Database Connectivity
,开放数据库连接
)
是微软公司开放服务结构中有关数据库的一个组成部分,它建立了一组规范,并提供了一组对数据库访问的标准
API
JDBC的分类(了解)
目前有四种可供使用的JDBC驱动程序,不同类型的的驱动程序有着不一样的使用方法,所以当我们在连接数据库之前,必须先依照我们的需求选择一个适当的驱动程序,这四种不同类型的驱动程序分别是:
1 JDBC-ODBC桥:桥接器型的驱动程序,
lJDBC-ODBC桥是在JDK中由SUN本身开发出来的一套数据库访问操作,
在JDBC-ODBC桥接中它的各种操作API都是最新的,但性能不高
l在JDK中,提供了JDBC-ODBC桥的实现类(sun.jdbc.odbc.JdbcOdbcDriver)
2 部分本地API部分Java的驱动程序,也是桥接器型驱动程序之一
l这种类型的JDBC驱动程序使用Java编写,它调用数据库厂商提供的本地API
l通过这种类型的JDBC驱动程序访问数据库减少了ODBC的调用环节,提高了数据库访问的效率
l在这种方式下需要在客户的机器上安装本地JDBC驱动程序和特定厂商的本地API
3 JDBC网络纯Java驱动程序
l这种驱动利用中间件的应用服务器来访问数据库。应用服务器作为一个到多个数据库的网关
,
客户端通过它可以连接到不同的数据库服务器。
l应用服务器通常有自己的网络协议,Java用户程序通过JDBC驱动程序将JDBC调用发送给
应用服务器,应用服务器使用本地程序驱动访问数据库,从而完成请求。
4 本地协议的纯Java驱动程序
:这类型的驱动程序是最成熟的JDBC驱动程序,不但无需在使用者计算机上安装任何额外的驱动程序,也不需在服务器端安装任何的中介程序(middleware),所有存取数据库的操作,都直接由驱动程序来完成
l多数数据库厂商已经支持允许客户程序通过网络直接与数据库通信的网络协议。
l这种类型的驱动程序完全使用Java 编写,通过与数据库建立的
Socket
连接,采用具体与厂商的网络协议把 JDBC 调用转换为直接连接的网络调用
JDBC API接口介绍
连接数据库的URL
lJDBC URL的标准由三部分组成,各部分间用冒号分隔。
•协议:<子协议>:<子名称>
•协议:JDBCURL中的协议总是jdbc
•子协议:子协议用于标识一个数据库驱动程序
•子名称:一种标识数据库的方法。子名称可以依不同的子协议而变化,用子名称的目的是为了定位数据库提供足够的信息
jdbc:mysql://localhost:3306/db_name
编码实现得到代表与数据库连接的Connection实现类对象三种方式
1使用driver接口的mysql实现类连接mysql数据库
lJava.sql.Driver 接口是所有JDBC 驱动程序需要实现的接口。这个接口是提供给数据库厂商使用的,不同数据库厂商提供不用的实现
采用注册驱动的方式
class.forName的方式(最常用 保证 方法二的静态代码块执行)
l
加载
JDBC
驱动需调用
Class
类的静态方法
forName
()
,向其传递要加载的
JDBC
驱动的类名
l
DriverManager
类是驱动程序管理器类,负责管理驱动程序
l
通常不用显式调用
DriverManager
类的
registerDriver
()
方法来注册驱动程序类的实例,因为
Driver
接口的实现类
都
包含了静态代码块,在这个静态代码块中,会调用
DriverManager.registerDriver
()
方法来注册自身的一个实例