JDBC代表JAVA DATA bASE Connectivity(Java数据库连接),它是一个标准的 Java API,用于 Java 编程语言和大量数据库之间的独立于数据库的连接。
JDBC库包括用于下面提到的每个任务的API,这些API通常与数据库使用相关联。
与数据库建立连接。
创建SQL或MySQL语句。
在数据库中执行SQL或MySQL查询。
查看和修改结果记录。
从根本上讲,JDBC是一种规范,提供了一组完整的接口,允许对基础数据库进行可移植的访问。Java可用于编写不同类型的可执行文件,例如-
Java 应用程序
Java 小程序
Java Servlet
Java ServerPage(JSP)
企业 JavaBean(EJB)。
所有这些不同的可执行文件都可以使用JDBC驱动程序来访问数据库,并利用存储的数据。
JDBC提供与ODBC相同的功能,从而允许Java程序包含独立于数据库的代码。
在继续之前,您需要对以下两个主题有充分的了解-
JDBC API支持用于数据库访问的两层和三层处理模型,但是通常,JDBC体系结构由两层组成-
JDBC API: 这提供了应用程序到JDBC管理器的连接。
JDBC Driver API: 这支持JDBC管理器到驱动程序的连接。
JDBC API使用驱动程序管理器和特定于数据库的驱动程序来提供与异构数据库的透明连接。
JDBC驱动程序管理器确保使用正确的驱动程序来访问每个数据源。驱动程序管理器能够支持连接到多个异构数据库的多个并发驱动程序。
以下是体系结构图,该图显示了驱动程序管理器相对于JDBC驱动程序和Java应用程序的位置-
JDBC API提供以下接口和类-
DriverManager:此类管理数据库驱动程序列表。使用通信子协议将来自Java应用程序的连接请求与适当的数据库驱动程序进行匹配。第一个在JDBC下识别特定子协议的驱动程序将用于建立数据库连接。
Driver:该接口处理与数据库服务器的通信。您很少会直接与Driver对象进行交互。而是使用DriverManager对象,该对象管理此类型的对象。它还抽象了与使用Driver对象相关的详细信息。
Connection:此接口包含用于联系数据库的所有方法。连接对象表示通信上下文,即,与数据库的所有通信仅通过连接对象进行。
Statement:您可以使用从此接口创建的对象将SQL语句提交到数据库。除执行存储过程外,某些派生接口还接受参数。
ResultSet:使用Statement对象执行SQL查询后,这些对象保存从数据库检索的数据。它充当迭代器,使您可以遍历其数据。
SQLException: 此类处理数据库应用程序中发生的所有错误。
java.sql和javax.sql是JDBC 4.0的主要包。这是撰写本教程时的最新JDBC版本。它提供了用于与数据源进行交互的主要类。
这些软件包中的新功能包括以下方面的更改:
自动数据库驱动程序加载。
异常处理方面的改进。
增强的BLOB / CLOB功能。
连接和语句接口的增强。
国家字符集支持。
SQL ROWID访问。
SQL 2003 XML数据类型支持。
注解。