JDBC1.0

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: JDBC是JAVA十三大规范之一,由JAVA定义顶级接口API,各个数据库厂商去实现。常用的四大接口——Driver,DriverManager,Connection,Statement。这里先给出结论:所谓的JAVA制定标准,就是指JAVA给出接口,厂家各自去实现。比如Driver,Connection,Statement等都是有接口,有实现。通过向DriverManager注册不同Driver来确定Connection,Statement的类型

JDBC是JAVA十三大规范之一,由JAVA定义顶级接口API,各个数据库厂商去实现。

20190731145350971.png

常用的四大接口——Driver,DriverManager,Connection,Statement。


这里先给出结论:


所谓的JAVA制定标准,就是指JAVA给出接口,厂家各自去实现。


比如Driver,Connection,Statement等都是有接口,有实现。


通过向DriverManager注册不同Driver来确定Connection,Statement的类型。


以下是JDBC的一个完整过程:

20190731151810197.png

Driver

java.sql下面的Driver

20190731145635948.png

com.mysql.jdbc中的mysql实现

可以看到继承了一个类,实现了java.sql.Driver接口。

最核心的操作就是向DriverManager中注册当前Driver,这就是切换驱动的核心动作。

20190731145714957.png

跟入父类,发现父类负责来实现了java.sql.Driver接口中的方法。

其实这里思考会发现父类已经实现了java.sql.Driver接口,Driver可以不用在实现的,设计者在这里的这一步显得多余了。

20190731145828106.png

该类的成员变量其实也就是连接MySQL必要的一些配置参数。

所以其实这个类就是Mysql驱动的核心。是为Mysql量身定做的驱动。

20190731145843228.png

DriverManager

从mysql的Driver中跟入DriverManager,会发现DriverManager属于java.sql。

20190731150743225.png

也就是说验证了之前的说法,JAVA提供了接口,不同数据库厂商去自行实现。Driver。

然后通过注册Driver到DriverManager中的方式来获取对应数据库类型的连接。

跟入registerDriver

20190731150829111.png

再跟入registerDriver,发现它将传过来的mysqlDriver加入了一个list

20190731150906404.png

Connection

这是java.sql中的Connection接口

20190731151009254.png

这是mysql对Connection接口的实现

2019073115102679.png

Statement

同理,这是java.sql中的接口

20190731151133231.png

这是com.mysql.jdbc中的实现

20190731151149164.png

同理resultSet等其他也是这种实现原理。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
SQL Java 关系型数据库
JDBC详解
Java Database Connectivity(JDBC)是Java语言中用于访问关系型数据库的标准接口,定义了一组API,使Java程序能以统一方式连接、访问和操作不同关系型数据库,简化数据库操作,提高Java应用程序的可移植性和可维护性。使用JDBC进行数据库操作主要包括创建数据源对象、建立连接、构造和执行SQL语句及释放资源等步骤。此外,还可以使用Set系列方法设置值,并使用get系列方法获取查询结果。
50 2
JDBC详解
|
2月前
|
SQL Java 关系型数据库
|
6月前
|
SQL Java 数据库连接
JDBC是真的啰里啰嗦啊-但是很重要!(下)
JDBC是真的啰里啰嗦啊-但是很重要!
28 1
|
6月前
|
Java 关系型数据库 MySQL
JDBC是真的啰里啰嗦啊-但是很重要!(上)
JDBC是真的啰里啰嗦啊-但是很重要!
41 1
|
XML 存储 Java
什么是jdbc?为什么要用jdbc
什么是jdbc?为什么要用jdbc
|
SQL Oracle 数据可视化
|
6月前
|
存储 Java 数据库连接
JDBC简单总结
JDBC简单总结
|
SQL 缓存 关系型数据库
JDBC的“那些事“之应当注意的问题(下)
JDBC的“那些事“之应当注意的问题(下)
|
SQL Java 关系型数据库
JDBC介绍
JDBC介绍
113 0
|
SQL druid Java
jdbc
全称:Java DataBase Connectivity, 意思就是 java连接数据库用到的,用来操作不同数据库的。
133 0