码农翻身——JDBC的诞生

随着 Oracle, Sybase, SQL Server ,DB2,  Mysql 等人陆陆续续住进数据库村, 这里呈现出一片兴旺发达的景象, 无数的程序在村里忙忙碌碌, 读写数据库,   实际上一个村落已经容不下这么多人了, 数据库村变成了数据镇。

 

这一天, 数据库镇发生了一件大事: 它连上了网络!

 

外部的花花世界一下全部打开,  很多程序开始离开这个拥挤的城镇, 住到更加宜居的地方去。

 

可是他们的工作还是要读写数据库, 大家都在想办法能不能通过网络来访问数据库镇的数据库。

 

其中移居到Tomcat村的Java 最为活跃, 这小子先去拜访了一下Mysql ,    相对于Oracle, Sybase 等大佬, Mysql 还很弱小, 也许容易搞定。

 

Java 说: “Mysql 先生, 现在已经网络时代了, 您也得与时俱进啊, 给我们开放下网络接口吧。 ”

 

Mysql  说: “还网络时代, 你们这些家伙越来越懒了, 都不愿意到我们家里来了! 说说吧, 你想怎么开放?  ”

 

Java 说: “很简单, 您听说过TCP/IP还有Socket 没有?   没有吗?!  没关系, 您的操作系统肯定知道, 它内置实现了TCP/IP和socket,   您只需要和他商量一下, 需要申请一个ip , 确定一个端口, 然后您在这个端口监听,  我每次想访问数据了, 就会创建一个socket ,向你发起连接请求, 你接受了就行了。 ”

“这么麻烦啊?”

 

“其实也简单, 您的操作系统会帮忙的, 他非常熟悉,  再说只需要做一次就行, 把这个网络访问建立起来, 到时候很多程序都会来访问您, 您会发财的。 ”

 

“不会这么简单吧, 假设说, 我是说假设啊,  通过socket我们建立了连接, 通过这个连接, 你给我发送什么东西?  我又给你发什么东西?”  Mysql非常老练, 直击命门。

 

“呃, 这个....  ”

 

Java 其实心里其实非常明白, 这需要和Mysql定义一个应用层的协议, 就是所谓的你发什么请求, 我给你什么响应。  

 

例如:

客户端程序先给Mysql 打个招呼,  Mysql也回应一下, 俗称握手。

 

怎么做认证、授权, 数据加密, 数据包分组。

 

用什么格式发送查询语句,   用什么格式来发送结果。

 

如果结果集很大, 要一下子全发过来吗?

 

怎么做数据缓冲?

......

等等一系列让人头痛的问题。

 

本来Java是想独自定义, 这样自己也许能占点便宜, 没想到Mysql  直接提出来了。

 

“这样吧 ” Java 说 “我们先把这个应用层的协议定义下来, 然后您去找操作系统来搞定socket如何? ”

 

“这还差不多 ” 。 Mysql 同意了。

 

两人忙活了一星期, 才把这个应用层协议给定义好。

 

然后又忙了一星期, 才把Mysql 这里的socket搞定。

 

Java 赶紧回到Tomcat村,  做了一个实验:  通过socket和mysql 建立连接,  然后通过socket 发送约定好的应用层协议,    还真不错, 一次都调通了,   看来准备工作很重要啊。

 

(刘欣注: 这是我的杜撰, mysql 的网络访问早就有了, 并不是java 捷足先登搞出来的)

搞定了Mysql ,  Java 很得意, 这是一个很好的起点, 以后和Oracle, SQL Server, Db2等大佬谈判也有底气了。

 

尤其是和mysql 商量出的应用层协议,   mysql 也大度的公开了, 这样一来, 不管是什么语言写的程序,管你是java, pyhton, ruby , php......   只要能使用socket,   就可以遵照mysql 的应用层协议进行访问,  mysql 的顾客呈指数级增长, 财源滚滚。  尤其是一个叫PHP的家伙, 简直和mysql 成了死党。

 

Oracle, Db2那帮大佬一看, 立刻就红了眼, 不到Java 去谈判, 也迫不及待的定义了一套属于自己的应用层访问协议。

 

令人抓狂的是, 他们的网络访问协议和Msyql 的完全不一样 !  这就意味着之前写的针对mysql 的程序无法针对Oracle , Db2通用,  如果想切换数据库, 每个程序都得另起炉灶写一套代码!

 

更让人恶心的是, 每套代码都得处理非常多的协议细节,   每个使用Java进行数据库访问的程序都在喋喋不休的抱怨: 我就想通过网络给数据库发送SQL语句, 怎么搞的这么麻烦?

 

原因很简单, 就是直接使用socket编程, 太low 了 ,  必须得有一个抽象层屏蔽这些细节!

 

Java 开始苦苦思索, 做出一个好的抽象不是那么容易的。

 

首先得有一个叫连接(Connection)的东西, 用来代表和数据库的连接。  

 

想执行SQL怎么办? 用一个Statement来 表示吧。   SQL返回的结果也得有个抽象的概念: ResultSet 。

他们之间的关系如图所示:

从Connection 可以创建Statement,    Statement 执行查询可以得到ResultSet。

 

ResultSet提供了对数据进行遍历的方法, 就是rs.next() , rs.getXXXX ....      完美!

 

对了, 无论是Connection, 还是Statement, ResultSet ,  他们都应该是接口,而不能是具体实现。

 

具体的实现需要由各个数据库或者第三方来提供, 毫无疑问, 具体的实现代码中就需要处理那些烦人的细节了!

 

Java 把这个东西叫做JDBC,  想着自己定义了一个标准接口, 把包袱都甩给你别人, 他非常得意。

第一个使用JDBC, 叫做学生信息管理的程序很快发现了问题,   跑来质问Java: “你这个Connection 接口设计的有问题!”

 

Java 说: “不可能, 我的设计多完善啊!”

 

“看来你这个规范的制定者没有真正使用啊,  你看看, 我想连接Mysql, 把Mysql 提供的jdbc实现(mysql-connector-java-4.1.jar )拿了过来,   建立一个Connection : ”

“这不是挺正常的吗? 你要连接Mysql , 肯定要提供ip地址, 端口号,数据库名啊” Java 问到。

 

“问题不在这里, 昨天我遇到mysql了, 他给了我一个号称性能更强劲的升级版mysql-connector-java-5.0.jar,  我升级以后, 发现我的代码编译都通不过了,  原来mysql 把MysqlConnectionImpl 这个类名改成了 MysqlConnectionJDBC4Impl  , 你看看, 你整天吹嘘着要面向接口编程, 不要面向实现编程, 但是你自己设计的东西都做不到啊”

 

Java觉得背上开始出汗,  那个程序说的没错,  设计上出了漏洞, 赶紧弥补吧。

 

既然不能直接去 new 一个Connection 的实现, 肯定要通过一个新的抽象层来做, 这个中间层叫做什么?

 

Java 想到了电脑上的驱动程序, 很多硬件没法直接使用, 除非安装了驱动。   那我也模拟一下再做一个抽象层吧: Driver

 

每个数据库都需要实现Driver 接口,   通过Driver 可以获得数据库连接Connection ,  但是这个Driver 怎么才能new 出来呢?  肯定不能直接new ,    Java似乎陷入了鸡生蛋、蛋生鸡的无限循环中了。

 

最后, 还是Java的反射机制救了他, 不要直接new 了,  每个数据库的Driver 都用一个文本字符串来表示, 运行时动态的去装载, 例如mysql 的Driver 是这样的:

Oracle是这样的:

只要这个Driver Class不改动, 其他具体的实现像Connection,  Statement, ResultSet想怎么改就怎么改。

 

接下来的问题是同一个程序可能访问不同的数据库, 可能有多个不同Driver 都被动态装载进来, 如何来管理?

 

那就搞一个DriverManager吧,  Mysql 的Driver, Oracle的Driver 在类初始化的时候, 一定得注册到DriverManager中来, 这样DriverManager才能管理啊:

注意: 关键点是static 的代码块, 在一个类被装载后就会执行。

 

DriverManager 可以提供一个getConnection的方法, 用于建立数据库Connection 。

DriverManager会把这些信息传递给每个Driver , 让每个Driver去创建Connection 。

 

慢着!  如果DriverManager  里既有MysqlDriver, 又有OracleDriver ,  这里到底该连接哪一个数据库呢?   难道让两个Driver 都尝试一下? 那样太费劲了吧, 还得区分开,没法子只好让那些程序在数据库连接url中来指定吧:

url中指明了这是一个什么数据库, 每个Driver 都需要判断下是不是属于自己支持的类型, 是的话就开始连接, 不是的话直接放弃。

 

(刘欣注: 每个Driver接口的实现类都需要实现一个acceptsURL(Sting url)方法, 判断这个url是不是自己能支持的。 )

 

唉,真是不容易啊, Java想, 这下整个体系就完备了吧, 为了获得一个Connection , 综合起来其实就这么几行代码:

无论是任何数据库, 只要正确实现了Driver, Connection 等接口, 就可以轻松的纳入到JDBC框架下了。

 

Java终于可以高兴的宣布: “JDBC正式诞生了!”

 

转自码农翻身微信公众号文章

JDBC的诞生

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/253252.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

码农翻身(随笔)

书一直都有在读,我会一直更新博文,欢迎大家前来阅读、指教! XML和注解 xml:应用于集中配置的场合,比如数据源的配置; 注解:像Controller、RequestMapping、Transactional这样的注解&#xff…

码农翻身摘录

三次握手:验证双方发信和收信能力问题  第一次握手:京城发信,县衙收到了,此时县衙就会明白,京城的发信能力和自己的收信能力没有问题。  第二次握手:县衙发信,京城收到了,此时京城就会明白,京城的发信和收…

《码农翻身》

大话编程 我是一个线程 我是一个Java class Javascript: 一个屌丝的逆袭 Java:一个帝国的诞生 JSP:一个装配工的没落 TCP/IP 之 大明王朝的邮差 TCP/IP 之 大明内阁 TCP/IP 之 蓟辽督师 CPU 阿甘 CPU 阿甘之烦恼 CPU 阿甘:函数调用的秘密 我是一个网卡 …

码农翻身

ISBN:978-7-121-34117-5 作者:刘欣 页数:324 推荐指数:★★★★★ 阅读日期:2020-02-04 用故事的形式来讲述技术, 从这个技术的诞生到如何发展优化, 一步步探究原理, 讲的非常生动形…

读书笔记(一)《码农翻身》

好久都没有写技术博客了,大概有一年左右没有开始写了,原因是自己弄了一个日志博文,当然这不是重点,重点是心态发生了改变,从心里上感觉技术兴趣不大了,后来又发现,并不是对技术失去了兴趣&#…

最担心的还是发生了,程序员失业来得太突然!

周末我在后台收到一条私信,事情很有代表性,这里分享一下。 这位老哥在一家互联网头部公司做了 6 年的技术,最好的年纪都留在了这家公司。上个月底,赶上所在的部门重组。 公司动作很快,开完年中回顾会就裁掉了一批人&am…

《码农翻身》之技术之路

《码农翻身》读书笔记之技术之路 这是我的后端读书笔记系列文章的第四三篇,选取的是最近刚刚圈粉的知名博主刘欣创作的《码农翻身》。这篇文章只是最后一部分内容。 本文内容主要根据知名博主刘欣一作《码农翻身》的内容总结而来,本书的内容风趣幽默&a…

码农翻身 各章节链接

大话编程 我是一个线程 我是一个Java class Javascript: 一个屌丝的逆袭 Java:一个帝国的诞生 JSP:一个装配工的没落 TCP/IP 之 大明王朝的邮差 TCP/IP 之 大明内阁 TCP/IP 之 蓟辽督师 CPU 阿甘 CPU 阿甘之烦恼 CPU 阿甘:函数调用的秘密 我是一个网卡 …

码农翻身全年文章精华

在码农翻身公众号写了一年多, 最大的体会就是:原创真心不易! 每天思考的最大问题就是: 下一篇文章写啥? 在大家的支持和鼓励下,还是坚持了下来, 回头看看走过的路,这一年过得还算…

python笔记16_实例练习_二手车折旧分析p1

python数据分析练习,具体数据不放出。 分析实践很简单。目的不是做完,而是讲清楚每一步的目的和连带的知识点(所以才叫学习笔记) 0.数据准备 原始数据格式:csv文件 原始数据结构: 数据格式 字段名 int…

MySQL第二章、数据库基础

回顾: 目录 一、数据库的操作 1.1创建数据库 1.2显示当前数据库 1.3使用数据库 1.4删除数据库 二、常用数据类型 2.1数值类型(分为整型和浮点型) 2.2字符串类型 2.3 日期类型 三、表的操作 ​编辑 3.1创建表 3.2查看表结构 ​编…

苹果手机如何实现微信多开分身

微信现在是生活中使用最多的聊天软件,而且很多人的微信都不止一个,一般都是一个用来工作使用,一个用来日常使用。 安卓手机在很早之前就可以安装两个微信了,目前还有部分用苹果的朋友不知道微信怎么分身,接下来小编就…

苹果手机如何微信分身?

苹果微信分身,既是你的生活伴侣,又是你的工作好帮手。对于那些工作繁忙,生活节奏快的人来说,这款产品非常实用。让你随时切换身份,一种生活,一种工作,既避免了不必要的误会和困扰,也…

苹果手机微信分身

QQ慢慢退出历史舞台后,我们的生活与工作又重新与微信拾起了联系,并且无法离开。虽然安卓用户很多都有自带两个微信,但由于系统的限制,iPhone手机还不能正常安装两个微信。那这些想安装两个微信的iPhone用户怎么办?iPho…

苹果微信分身版ios_微信正式支持暗黑模式:iOS版已上线 安卓版随后就来

微信暗黑模式一直受到网友的极大期待,今天(22日),微信 iOS版 终于迎来了 7.0.12 更新,正式加入对深色模式的支持。 微信 7.0.12 更新日志显示可跟随系统的设置,切换为深色模式。 从目前网友的反馈来看,一方面对微信终于…

苹果微信分身版ios_苹果手机ios14系统微信分身地址安装教程

大家期待已久的苹果12终于也到来了。是否达到了你的预期?惊喜多还是失望多呢? 随着苹果12的到来,市面上百分之80的苹果手机用户的苹果手机系统版本都更新到了ios14版本了。ios14系统可以说在使用体验上给用户们有很大的视觉提升跟操作舒心。为…

微信分身服务器,苹果微信分身版

苹果微信分身版 定制技巧一、怎样去做做seo?出现seo,一看就知道。seo如同天上掉馅饼,做到专注优化,那么就是正确的seo,后面的会做出***好的seo。 打造微信中的自我推广、商业协同等。微信公众平台做业务流程也可以分为…

苹果微信分身版使用教程与注意事项

许多苹果手机用户都听说过:苹果微信分身版这一款手机软件,不过,什么是苹果微信分身版?微信分身版有什么功能?还有,苹果微信分身版怎么使用呢?相信这一些问题大家都不知道,在今天的教…

多开分身苹果版_苹果手机最新微信分身怎么下载?微信多开地址分享

哇 放假了 大家端午节快乐安康。简直不要太开心。 苹果用户们都知道苹果系统已经升级到IOS14了。喜欢升级的朋友们会发现微信分身都不能用了。怎么办呢?终归不会凉拌。我的出现就是来拯救你们的,对。 已经升级到ios14系统的朋友不要着急,船到桥头自然直,下面这款微信分身就…

苹果应用分身_苹果手机微信分身怎么下载?微信多开版地址

周一了,新的一周开始了,小伙伴们这周要加油啊。 小伙伴们这周的工作有没有有效率的完成呢??如果没有,那可能是因为你缺少一个稳定的微信分身。何为微信多开? 顾名思义就是在一个手机上安装两个乃至多个微信。对 ,就是这个意思了。如下图所示 很多人在苦恼,找了那么多年…