什么是JDBC?一篇关于Java API的文章

目录

JDBC 概述

Java 的执行流程:

  JDBC架构

双层架构:

三层架构:

常见的 JDBC 组件

DriverManager: 

Driver:

Connection:

Statement:

ResultSet:

SQLException:


 

作为一位Java 工作者的开发人员,日常跟 API 打交道无疑是家常便饭,那么,你了解 API 吗?

在开发中,我们使用的是 Java 语言,那么就要通过  Java 语言操作数据库中的数据。这就是接下来要进行的 JDBC 。

JDBC 概述

JDBC 全称 : Java DataBase Connectivty (Java 数据库连接)

Java 数据库连接,是一种标准Java应用编程接口( JAVA API),用来连接 Java 编程语言和广泛的数据库。

JDBC 是使用 Java 语言操作关系型数据库的一套 API 。

我们开发的一套 Java 代码是无法操作不同的关系型数据库,因为每一个关系型数据库的底层实现细节不一样。 

 既然是这样,问题来了

如果在公司中可以在开发阶段使用的是MySQL数据库,而上线时公司最终选用oracle数据库,我们就需要对代码进行大批量修改,这显然并不是我们想看到的。我们要做到的是同一套Java代码操作不同的关系型数据库,而此时sun公司就指定了一套标准接口 (JDBC),JDBC中定义了所有操作关系型数据库的规则。众所周知,接口是无法直接使用的,我们需要使用接口的实现类,而这套实现类(称之为:驱动)就由各自的数据库厂商给出。

如下图,每个数据库都可以使用同一套 JDBC 接口,这就形成了同一套代码操作不同的关系型数据库。

使用 JDBC 最大的优势就是,各个数据库厂商使用相同的接口,Java 代码不需要针对不同数据库分别开发,并且还可以随时替换底层数据库,访问数据库的 Java 代码基本不变。

JDBC API 允许用户访问任何形式的表格数据,尤其是存储在关系数据库中的数据。

Java 的执行流程:

  • 连接数据源,如:数据库。

  • 为数据库传递查询和更新指令。

  • 处理数据库响应并返回的结果。


JDBC API 库包含下面提到的每个任务,都是与数据库相关的常用用法。

  •   制作到数据库的连接。
  •   创建 SQL 或 MySQL 语句。
  •   执行 SQL 或 MySQL 查询数据库。
  •   查看和修改所产生的记录。

从根本上来说,JDBC 是一种规范,它提供了一套完整的接口,允许便携式访问到底层数据库,因此可以用 Java 编写不同类型的可执行文件,例如:

  •    Java 应用程序
  •    Java Applets
  •    Java Servlets
  •   Java ServerPages (JSPs)
  •   Enterprise JavaBeans (EJBs)

所有这些不同的可执行文件就可以使用 JDBC 驱动程序来访问数据库,这样可以方便的访问数据。

JDBC 具有 JDBC 一样的性能,允许 Java 程序包含与数据库无关的代码。


JDBC API 库包含下面提到的每个任务,都是与数据库相关的常用用法。

   制作到数据库的连接。

   创建 SQL 或 MySQL 语句。

   执行 SQL 或 MySQL 查询数据库。

   查看和修改所产生的记录。


JDBC 的 API 支持两层和三层处理模式进行数据库访问,但一般的 JDBC 架构由两层处理模式组成:

JDBC API: 提供了应用程序对 JDBC 管理器的连接。
    
JDBC Driver API: 提供了 JDBC 管理器对驱动程序连接。

JDBC API 使用驱动程序管理器和数据库特定的驱动程序来提供异构(heterogeneous)数据库的透明连接。

JDBC 驱动程序管理器可确保正确的驱动程序来访问每个数据源。该驱动程序管理器能够支持连接到多个异构数据库的多个并发的驱动程序。

  JDBC架构

JDBC架构分为双层架构和三层架构。

下面说一下双层架构,及作用、条件、机制、部署。

双层架构:

作用:此架构中,JavaApplet 或应用直接访问数据源。 

条件:要求 Driver 能与访问数据库交互。

机制:用户命令传给数据库或其他数据源,随之结果返回。

部署:数据源可以在另一台机器上,用户通过网络连接,称为 C/S 配置(可以是内联网或互联网)。

三层架构:

 侧架构特殊之处在于,引入中间层服务。

流程:可以增加企业数据的访问控制,以及多种类型的更新;另外,也可简化应用的部署,并在多数情况下有性能优势。

历史优势:以往,因性能问题,中间层都用 C或 C++ 编写,随之着优化编译器(将 Java 字节码转为高效的特定机器码)和技术的发展,如 EJB,Java 开始用于中间层的开发这也让 Java 的优势突显出来,使用 Java 作为服务器代码语言,JDBC 随之被重视。

常见的 JDBC 组件

JDBC 的 API 提供了以下接口和类:

DriverManager: 

这个类管理一系列数据库驱动程序。匹配连接使用通信子协议从 Java 应用程序中请求合适的数据库驱动程序。识别 JDBC 下某个子协议的第一驱动程序将被用于建立数据库连接。

Driver

这个接口处理与数据库服务器的通信。你将很少直接与驱动程序互动。相反,你使用 DriverManager 中的对象,它管理此类型的对象。它也抽象与驱动程序对象工作相关的详细信息。 

Connection

此接口具有接触数据库的所有方法。该连接对象表示通信上下文,即,所有与数据库的通仅通过这个连接对象进行。

Statement

使用创建与这个接口的对象将 SQL 语句提交到数据库。除了执行存储过程以外,一些派生的接口也接受参数。

ResultSet

在你使用语句对象执行 SQL 查询后,这些对象保存从数据库获得的数据局。它作为一个迭代器,让你可以通过它的数据来移动。

SQLException

这个类处理发生在数据库应用程序的任何错误。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值