JDBC简介

在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:桥接器型的驱动程序,

lJDBCODBC桥是在JDK中由SUN本身开发出来的一套数据库访问操作,
JDBCODBC桥接中它的各种操作API都是最新的,但性能不高
lJDK中,提供了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 () 方法来注册自身的一个实例















  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值