MySQL | JDBC连接数据库详细教程-1

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL | JDBC连接数据库详细教程

一、什么是JDBC?

JDBC,即Java Database Connectivity,java数据库连接。是一种用于执行SQL语句的Java API,它是Java中的数据库连接规范。这个API由 java.sql.*,javax.sql.* 包中的一些类和接口组成,它为Java开发人员操作数据库提供了一个标准的API,可以为多种关系数据库提供统一访问

二、JDBC工作原理

JDBC 为多种关系数据库提供了统一访问方式,作为特定厂商数据库访问API的一种高级抽象,它主要包含一些通用的接口类

下面是我画的一张有关JDBC访问数据库层次结构的图:

可以看到,我们程序员在开发JavaEE应用的时候,通过调用Sun公司提供给我们的JDBC相关API,就可以切访问数据库的JSBC驱动程序,继而通过驱动来加载数据库

image.png JDBC优势:

  1. Java语言访问数据库操作完全面向抽象接口编程
  2. 开发数据库应用不用限定在特定数据库厂商的API
  3. 程序的可移植性大大增强

三、使用JDBC连接MySQL数据库【✔】

1、安装对应数据驱动包

那有同学就问了,数据驱动包是什么?

💬 对于数据驱动包而言,其实就是上面我所说到的各个【数据库厂商】所提供给我们的JDBC驱动程序,因为只有数据库厂商那边提供给了我们加载数据库的驱动,我们才能去获取到数据库中的数据表然后进行CRUD等操作

  • 这样说呢可能还不是很好理解,我们可以通过画图来帮助理解,知道了JDBC的工作原理后,我们还要去了解什么去驱动包

image.png

接下去就要去下载这个驱动包,去哪里下呢?当然是官网

  • 但是呢,官网很麻烦,你要一个个地去找,不知道要下那个才好,下面是MySQL的官网的驱动下载处,很好找。但若是你用的是Oracle数据库的话,就会很麻烦了,因为它们这家公司很大,产品也很多,所以官网中会很很多东西,你很难去找到自己想要的驱动程序

image.png

难道这就没办法了吗?要一个个找吗😥当然有,那就是我们心爱的【Maven

  • 对于Maven而言,学Java的同学一定不陌生,它是一个 “中央仓库”,Maven 作为 Java 项目管理工具,它不仅可以用作包管理,还有许多的插件,可以支持整个项目的开发、打包、测试及部署等一系列行为,简直是居家旅行、杀人灭口必备良药!
  • 咳咳,然后我们就可以去下载MySQL对应的驱动包了,按照下图指示来即可

image.png

  • 点进去之后就可以选择对应的驱动包版本了,但是这里在选择的时候要注意了,需要和你MySQL安装的版本一致才可,我的MySQL是5.7的,所以这里大版本不能变,要选择5.1开头的,后面的小版本没关系;当然如果你的MySQL是8.x版本的,你就要选择8开头的驱动包了

image.png

  • 点进去之后我们看到有个jar,点一下它,你就可以拥有一个MySQL相关的驱动包了,就和我们平常使用的.rar.zip压缩包没什么区别,就是Java的压缩包以.jar结尾

image.png

  • 下载好了之后就是这个样子的

image.png

2、将jar包导入项目中

现在我们有了这个jar后,就要把它用起来

  • 那现在我们去新建一个项目,然后把这个包导进来,不过在此之前要新建一个名为lib的目录,它是library库的缩写,当然你也可以写其他的名称

image.png

  • 然后右键这个目录选择【添加为库...】

image.png

  • 此时这个MySQL的驱动库就导入到我们的项目中了

image.png

3、编写代码连接数据库【⭐】

加载完MySQL的驱动包之后,我们就可以使用一些API去操作数据库了,准备好了吗,发车了:car:

1️⃣ 创建数据源

👉首先第一点,要连接数据库的话,我们就要知道这个数据库在哪里

  • 这里我会介绍两种方式,一个是通过DataSource(数据源)对象获取,另一种则是通过DriverManager(驱动管理类)的静态方法获取,不过重点在于第一种

DataSource(数据源)对象获取

DataSource dataSource = new MysqlDataSource();
((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8&useSSL=false");
((MysqlDataSource)dataSource).setUser("root");
((MysqlDataSource)dataSource).setPassword("xxxxxxxxxxx");
  • 也就是这一句我使用到了向上转型,DataSource是Java中的一个接口,MysqlDataSource则是它的实现类,下面这种便是很典型的使用接口来实现==向上转型==
DataSource dataSource = new MysqlDataSource();
  • 然后下面的setURL()setUser()setPassWord()都是【MysqlDataSource】这个接口实现类中的一些方法,但是由于向上转型后父类无法去调用子类独有的方法,所以我们还要去进行一个==向下转型==
  • 通过去进行一个强制类型转换就可以做到,此时我们便能调用到实现类中的方法了
((MysqlDataSource)dataSource).setURL(...)
((MysqlDataSource)dataSource).setUser(...)
((MysqlDataSource)dataSource).setPassWord(...)

💬 那有同学问:为什么要这么麻烦呢?转上又转下?直接使用MysqlDataSource不就好了

  • 道理确实是这样,如果我们直接将代码写成下面这样子,那么就可以直接去调用这个类中的方法了,无需再去做一个向下转型,但是这却隐藏着巨大的隐患...
MysqlDataSource dataSource1 = new MysqlDataSource();

可能没有真正做过开发的同学还体会不到这一点,因为我们在设计一些接口、类的时候始终要遵循【高内聚 · 低耦合】的思想,==即类的内部各个方法之间要紧密关联,但类与类之间不要产生太大的依赖==

  • 光这么说可能说不太清楚,有兴趣的同学可以先去了解一下高内聚 · 低耦合
  • 因为在上面我们使用的是【MysqlDataSource 】,所以在程序的其他方法中,我们可能也需要使用到这个类去做一个接受,就是因为这种==高内聚==的原因,导致了【MysqlDataSource 】被大量地进行扩散,此危害性就在于后续我们的项目要更换数据库的就需要改动很多的代码,加大了工作量!!!
void func1(MysqlDataSource dataSource1){}
void func2(MysqlDataSource dataSource2){}

然后呢我们再来说说为什么要去调用这些API

  • 首先的话是serURL(),对于【URL】来说,学习过HTTP协议的同学应该是非常熟悉,对于浏览器发送的HTTP请求中第一行就是URL,它叫做 统一资源定位符,也就是我们日常生活中所说的【网址】,描述了互联网上唯一一个资源的位置

我们可以来解读一下这个所传入的这个URLimage.png

  • 那对于下面的UserPassWord就很清楚了,就是用户名和密码,MySQL用户名固定就是【root】,密码的话就是你安装MySQL的时候手动设置的密码。
  • 虽然很多数据库是根据用户名和密码来进行认证的,但是有些数据库,向SQLite就不是用的这个进行认证,所以这就是为什么这些方法均在【MysqlDataSource 】里的原因了,每个数据库都有它们独特的验证方式,所以我们在使用不同数据库时加载不同的驱动包即可

2️⃣ 和数据库建立网络连接

在上面呢,我们只是进行了数据源的创建操作,只是描述了服务器在哪,并没有真正得进行访问,那现在我们所要做的操作就是【连接】,通过网络去进行一个通信

  • 然后我们就可以通过【DataSource】接口中一个方法叫做getConnection()这个方法去建立一个网络连接,它会返回一个实例为【Connection】的对象,不过从下图可以看到很多种类的Connection,那我们选哪个呢?
  • 这里要注意,选择这个java.sql的,这才是我们想要的Connection

image.png

Connection connection = dataSource.getConnection();
  • 要注意这里了连接(Connection),而不是链接(Link),对于连接而言并不复杂,因为只有这么一句代码,因为在网络中客户端和服务器之间要去建立一个连接,就只是找个地方记录下而已,并不需要非常繁琐的步骤
  • 而且还要注意的是这个getConnection()还需要去处理异常,一般来说像我们在进行文件读取、数据库操作都是需要去捕获这个异常的,这里我直接【throws】了,你也可以【try..catch】,如果异常还不是很了解的同学再去学习一下

image.png

打个比方说,就像民政局登记结婚一样,只是找个地方登记一下我们结婚了,也无需像婚礼那样大动干戈


DriverManager(驱动管理类)的静态方法获取

讲了这么多,别忘了我们只讲了一种数据库连接方式,别忘了还有第二种,那就是使用DriverManager

  • 但是我并不打算讲解这种方式,因为它需要借助我们在JavaSE中所学习的【反射】,但是对于反射来说其实是不属于常规的编程手段,不在特殊的情况下还是不推荐使用的。你可以在看了下面这两种连接方式的区别后再来回顾
// 加载JDBC驱动程序
Class.forName("com.mysql.jdbc.Driver");
// 创建数据库连接
Connection connection = DriverManager.getConnection(url);

区别:

  1. DriverManager类来获取的Connection连接,是无法重复利用的,每次使用完以后释放资源时,通过connection.close()都是关闭物理连接
  2. DataSource提供连接池的支持。连接池在初始化时将内置了【数据库连接池】,这些连接是可以复用的,每次使用完数据库连接,释放资源调用connection.close()都是将Conncetion连接对象回收

💬 可能有同学对这个【数据库连接池】不太理解,我们这里来讲一讲(doge)

  • 在Java中呢我们学习过很多的,比方说:String字符串常量池、进程池、线程池、内存池,它们都是池
  • 那谈到池这个东西我们就想到了【池塘】,那假设呢你现在是个妹子,长得好看,又有才华,所以追求者就与很多,但是呢同一时间只能谈一个对象,但是你又不想拒绝其他的追求者,因为如果当前这个对象谈到后面谈不来的话,就需要再换一个,此时的话就会有很多的成本,因为需要重新培养感情


  • 那于是你就想了一个很不错的办法来提高效率,那就是【养鱼🐟】
  • 怎么养鱼呢?也就是在和A谈对象的同时和B搞暧昧,同时培养感情基础,一旦你和A分手了,就可以立马和B在一起,此时大大提高了效率,那么这个B就被亲切地称之为【备胎】

image.png

  • 但是你的备胎可能还不只B这一个,可能还有CDEFGHI.....,此时它们就构成了一个“备胎池”,若是B不合适了还可以换其他人上位,而且呢,这个时候A也还在池子里,若是你和其他人都不和的时候,又想到A了,此时你就可以再和A在一起

当然,上面只是举一个小小的案例,现实生活中我们不提倡这么去做~ 但是在计算机里这种做法还是很常见的,可以了解一下

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
26天前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
119 26
|
13天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
39 3
|
13天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
42 3
|
13天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE 'log_%';`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
54 2
|
27天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
184 15
|
20天前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。
|
27天前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
1月前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
2月前
|
关系型数据库 MySQL 数据库
GBase 数据库如何像MYSQL一样存放多行数据
GBase 数据库如何像MYSQL一样存放多行数据
|
2月前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
48 1