JDBC1.0

本文涉及的产品
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 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是真的啰里啰嗦啊-但是很重要!(下)
JDBC是真的啰里啰嗦啊-但是很重要!
12 1
|
2月前
|
存储 Java 数据库连接
JDBC简单总结
JDBC简单总结
|
10月前
|
XML 存储 Java
什么是jdbc?为什么要用jdbc
什么是jdbc?为什么要用jdbc
|
11月前
|
SQL Oracle 数据可视化
|
11月前
|
SQL 人工智能 数据可视化
JDBC的“那些事“之应当注意的问题(上)
JDBC的“那些事“之应当注意的问题(上)
|
缓存 druid Java
JDBC2.0
JDBC2.0在1.0版本java.sql.*上增加了一个扩展包javax.sql.*包,这个包里面包含两个接口: 1.DataSource,数据源。 2.ConnectionPoolDataSource,数据池。 DataSource的源码可以看到,这个接口的作用就是拿来获取connection连接的。 各个数据库厂商只负责实现connection, 至于获取connection,在JDBC1.0里面是由DriverManager来负责的。 JDBC2.0版本之所新增DataSource,原因很简单——数据库连接池。1.0版本时每用一次connection都需要重新new,而da
102 0
JDBC2.0
|
SQL 安全 Java
33 JDBC实用详解
info 💡 概念:JDBC是java提供的一套用于操作数据库的接口API:java程序员只需要面向这套接口编程即可;
77 0
|
SQL 安全 Java
|
Java 数据库连接 测试技术
|
SQL druid Java
jdbc
全称:Java DataBase Connectivity, 意思就是 java连接数据库用到的,用来操作不同数据库的。
116 0