【JDBC4.2】一、JDBC简介

2024-05-31 22:58
文章标签 jdbc 简介 jdbc4.2

本文主要是介绍【JDBC4.2】一、JDBC简介,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

注意:本编文章以下代码均为简写方式,无法执行,仅供参考

1. JDBC的由来

直接使用socket协议访问数据库

应用程序可以直接通过多种方式访问数据库,最普通的是通过socket访问数据库。以Mysql 为例:首先通过程序通过socket和数据库建立了TCP连接,把准备执行的SQL语句或命令封装成特定于Mysql 数据库的应用层数据包,发送给Mysql 数据库,Mysql数据库执行命令,将结果封装成数据包并返回给应用,应用程序进行解析,显示结果给客户端。如下图所示:

这里写图片描述


访问数据库的抽象层–JDBC

令人抓狂的是,Oracle, DB2,Postgresql等其他数据库都有一套属于自己的应用层访问协议。 他们的网络访问协议和Mysql 的完全不一样 ! 这就意味着之前写的针对Mysql 的程序无法针对其他数据库通用, 如果想切换数据库, 每个程序都得另起炉灶写一套代码!直接使用socket访问数据库耦合度太高了,必须得有一个抽象层屏蔽这些细节!
为此,JDK专门提供了一系列针对这个抽象层的统一接口—JDBC(Java Data Base Connectivity,java数据库连接),称为JDBC规范。数据库厂商需要实现JDBC规范中的某些接口(实现中应包含特定数据库的应用层协议的转换/解析等),这些接口统被称为 XX数据库驱动 。如下图所示
这里写图片描述
数据库厂商实现这些接口一般以单个的jar文件发布,如:
mysql-connector-java-5.1.40.jar(Mysql)
ojdbc14.jar(Oracle)


2. JDBC的发展

参考我的另一篇文章 link


3.JDBC的一些接口

java.sql.Connection接口

JDBC规范中用Connection接口用来代表程序和数据库的Socket连接。数据库厂商必须实现这个接口。

使用java.sql.Driver

JDBC规范了一个抽象层吧: Driver接口。每个数据库都需要实现Driver 接口, 通过Driver 可以获得特定数据库的Connection 。 这样就避免了直接调用特定Connection的耦合性。

Driver driver=new com.abc.Driver();
//获取DB连接
Connection connection = driver.connect("url","user","pwd");

工厂类java.sql.DriverManager

如果要访问多个数据库—JDBC提供了DriverManager类,使用它可以注册不止一个Driver,方便获取对应数据库Connection。你可以这样写:

//注册一个数据库驱动/如果换用其他厂商的数据库驱动,直接在这里换其他Driver
DriverManager.registerDriver(new com.abc.Driver());
DriverManager.registerDriver(new com.ssss.Driver());
//获取连接
Connection connection = DriverManager.getConnection("url","user","pwd");

Driver会根据url来调用注册在DriverManager中的每个Driver相应方法,来判断是否支持这个url,如果是则返回特定的Connection。

进一步简化

在JDBC4.0以后,你可以这样写:

Connection connection = DriverManager.getConnection("url","user","pwd");

DriverManager会自动加载ClassPath中所有的Driver实现类,而每个Driver类被加载时,会自动注册到DriverManager中(在静态代码块static{}中实现注册)。

4. 开发环境

JDK版本

版本1.8

IDE

InteliJ IDEA 2016

maven依赖

<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>6.0.5</version>
</dependency>

数据库信息

类型:mysql
版本: 5.7
IP: localhost
端口:3306
库名:test
用户名: root
密码: 123456
表: student
表结构:

CREATE TABLE `student` (`name` varchar(5) NOT NULL,`age` int(11) DEFAULT NULL,PRIMARY KEY (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

5. 参考文献

1.JDBC™ 4.2 Specification : JSR 221(Lance Andersen, Specification Lead)March 2014

这篇关于【JDBC4.2】一、JDBC简介的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1019275

相关文章

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

滚雪球学Java(87):Java事务处理:JDBC的ACID属性与实战技巧!真有两下子!

咦咦咦,各位小可爱,我是你们的好伙伴——bug菌,今天又来给大家普及Java SE啦,别躲起来啊,听我讲干货还不快点赞,赞多了我就有动力讲得更嗨啦!所以呀,养成先点赞后阅读的好习惯,别被干货淹没了哦~ 🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!! 环境说明:Windows 10

业务协同平台--简介

一、使用场景         1.多个系统统一在业务协同平台定义协同策略,由业务协同平台代替人工完成一系列的单据录入         2.同时业务协同平台将执行任务推送给pda、pad等执行终端,通知各人员、设备进行作业执行         3.作业过程中,可设置完成时间预警、作业节点通知,时刻了解作业进程         4.做完再给你做过程分析,给出优化建议         就问你这一套下

容器编排平台Kubernetes简介

目录 什么是K8s 为什么需要K8s 什么是容器(Contianer) K8s能做什么? K8s的架构原理  控制平面(Control plane)         kube-apiserver         etcd         kube-scheduler         kube-controller-manager         cloud-controlle

【Tools】AutoML简介

摇来摇去摇碎点点的金黄 伸手牵来一片梦的霞光 南方的小巷推开多情的门窗 年轻和我们歌唱 摇来摇去摇着温柔的阳光 轻轻托起一件梦的衣裳 古老的都市每天都改变模样                      🎵 方芳《摇太阳》 AutoML(自动机器学习)是一种使用机器学习技术来自动化机器学习任务的方法。在大模型中的AutoML是指在大型数据集上使用自动化机器学习技术进行模型训练和优化。

SaaS、PaaS、IaaS简介

云计算、云服务、云平台……现在“云”已成了一个家喻户晓的概念,但PaaS, IaaS 和SaaS的区别估计还没有那么多的人分得清,下面就分别向大家普及一下它们的基本概念: SaaS 软件即服务 SaaS是Software-as-a-Service的简称,意思是软件即服务。随着互联网技术的发展和应用软件的成熟, 在21世纪开始兴起的一种完全创新的软件应用模式。 它是一种通过Internet提供

Hibernate框架中,使用JDBC语法

/*** 调用存储过程* * @param PRONAME* @return*/public CallableStatement citePro(final String PRONAME){Session session = getCurrentSession();CallableStatement pro = session.doReturningWork(new ReturningWork<C

LIBSVM简介

LIBSVM简介 支持向量机所涉及到的数学知识对一般的化学研究者来说是比较难的,自己编程实现该算法难度就更大了。但是现在的网络资源非常发达,而且国际上的科学研究者把他们的研究成果已经放在网络上,免费提供给用于研究目的,这样方便大多数的研究者,不必要花费大量的时间理解SVM算法的深奥数学原理和计算机程序设计。目前有关SVM计算的相关软件有很多,如LIBSVM、mySVM、SVMLight等,这些

urllib与requests爬虫简介

urllib与requests爬虫简介 – 潘登同学的爬虫笔记 文章目录 urllib与requests爬虫简介 -- 潘登同学的爬虫笔记第一个爬虫程序 urllib的基本使用Request对象的使用urllib发送get请求实战-喜马拉雅网站 urllib发送post请求 动态页面获取数据请求 SSL证书验证伪装自己的爬虫-请求头 urllib的底层原理伪装自己的爬虫-设置代理爬虫coo

新一代车载(E/E)架构下的中央计算载体---HPC软件架构简介

老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明自己,无利益不试图说服别人,是精神上的节能减排。 无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事.而不是让内心的烦躁、焦虑、毁掉你本就不多的热情和定力。 时间不知不觉中,快要来到夏末秋初。一年又过去了一大半,成