MySQL 篇- Java 连接 MySQL 数据库并实现数据交互

🔥博客主页: 【小扳_-CSDN博客】
❤感谢大家点赞👍收藏⭐评论✍

文章目录

        1.0 JDBC 概述

        2.0 实现 Java 连接 MySQL 数据库并实现数据交互的完整过程 

        2.1 安装数据库驱动包

        2.2 创建数据源对象

        2.3 获取数据库连接对象

        2.4 创建 SQL 语句

        2.5 执行 SQL 语句

        2.6 释放资源

        3.0 完整代码


        1.0 JDBC 概述

        JDBC(Java Database Connectivity)是 Java 编程语言用于与数据库进行交互的标准 API。它提供了一种统一的方式来访问不同数据库系统,并执行 SQL 查询、更新和管理数据库。

        通过 JDBC,开发人员可以轻松地连接到数据库、执行 SQL 查询、管理事务、处理异常等,实现与数据库的数据交互和管理。

        简单来说,Java 提出的一套关于数据库操作的接口,各个数据库厂商要把自己的 API 对接到适配到 JDBC 上。程序元只需要掌握一套 API 就可以操作不同的数据库了。

        2.0 实现 Java 连接 MySQL 数据库并实现数据交互的完整过程 

        2.1 安装数据库驱动包

        数据库厂商提供的这个原生 API 适配到 JDBC 转换程序,称为“数据库驱动包”。需要下载这个 .jar 文件,一个 .jar 文件通常包含了数据库厂商实现的 JDBC 接口。一个 .jar 文件是用来提供 JDBC 接口的实现,以便 Java 程序可以通过 JDBC API 与数据库进行交互。可以通过中央仓库来下载数据库驱动包:https://mvnrepository.com/

接着将 .jar 文件导入到 Java 文件目录中

1)接着,将 .jar 文件复制粘贴到 Java 文件目录中:

2)最后,右击 .jar 文件再点击添加为库:

3)添加成功的展示:

        2.2 创建数据源对象

        创建数据源是在应用程序中连接到数据库的一种常见方法。数据源通常是一个对象,它包含了连接数据库所需的信息,如 MySQL 数据库地址、用户名、密码。不同的数据库需要设置的参数有所不同。

        在 Java 中创建数据源并且连接到数据库服务器中相当于实现一个数据库客户端。

创建数据源代码:

        //1.0 创建数据源DataSource dataSource = new MysqlDataSource();((MysqlDataSource)dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/db01?characterEncoding=utf8&useSSL=false");((MysqlDataSource) dataSource).setUser("root");((MysqlDataSource) dataSource).setPassword("123456");

        首先 new 一个 MySQL 数据源,这里用到了向上转型,利用了多态特性。创建完数据源的对象后,需要对属性、方法进行设置:由于每一个数据库的方法都有所差别,需要用到向下转型,来专门访问数据库自己特有的方法、属性。

        比如,MySQL 中需要设置数据库服务器资源路径:

setUrl("jdbc:mysql://127.0.0.1:3306/数据库名?characterEncoding=utf8&useSSL=false") :该路径的大部分结构是不用改变的,一般情况下,只有唯一的参数,就是数据库名称。

setUser("用户名"):设置用户名,默认情况是 root ,root 是权限最大的账户。

setPassword("密码"):密码输入。

        2.3 获取数据库连接对象

        通过数据源对象获取数据库连接,以便在 Java 代码中执行数据库操作。通过得到的数据源对象 dataSource 的方法 getConnection() 从而获取数据库连接该对象。

        这个 Connection 对象,就代表着客户端与服务端之间的“连接对象”。 

代码如下:

        //2.0 与数据库建立联系Connection connection = dataSource.getConnection();

        需要注意的是,getConnection() 属于受查异常,可能会抛出 SQL Exception 异常。有两种方法解决:第一种,声明异常;第二种,捕获异常处理。

        一般来到这里,顺利的话,就可以获取 connection 对象了。

经常出错的情况:

        出错一:Connection 类型选错

        很容易根据提示,会选择错误。正确的是选择第一个 Connection 是 JDBC 中的一个接口。

        出错二: MySQL 版本与数据库驱动包的版本不一致导致的错误

        即使两者之间的大版本相同,但是小版本不相同,可能也会出错。比如,MySQL8.0 的版本与 mysql-connector-java-8.0.7-dmr.jar 数据库驱动包,大版本都是 8.0 但是小版本不一致,也有可能出错,从而导致连不上数据库服务器,建议多试试几个版本的数据库驱动包。不过有其他方法来解决即使小版本不一致也可以正常连接上数据库服务器。

        其他原因有很多种,包括不限于:

        1)数据库服务器没有正确启动

        2)url 写错了

        3)用户名写错了

        4)密码写错了

        5)网络断开了

补充:进行客户端 - 服务器之间通信的时候,常见有两种通信的模式:

        1)有连接(JDBC 属于有连接):比如,打电话,需要对方接通电话才可以进行对话,要是对方挂断了,就没通信了。

        2)无连接:比如,微信发消息,不需要对方接通才能发送消息。无论对方是否接受,我都能把数据给发过去。

        2.4 创建 SQL 语句

        虽然是通过 Java 来操作数据库,实际上核心还是 SQL ,只不过是把 SQL 语句嵌入带 Java 中。

1)首先,用字符串的形式创建一条 SQL 语句。

2)接着,通过连接对象 connection 的方法 prepareStatement(字符串变量),将字符串进行预编译处理。

代码如下:

        // 3.0 创建SQL语句String sql = "insert into student values('张三三',14)";PreparedStatement preparedStatement = connection.prepareStatement(sql);

补充:如果一个字符串 sql 发送到数据库服务器上,是要先对 sql 进行解析,进行各种校验(判定 sql 是否符合语法要求等),这个解析操作也是要花费一定的开销,虽然开销不大,但是 mysql 服务器要同时给多个客户端提供服务,为了减轻数据库服务器的负担,就可以在客户端这边完成,此时把解析后的结果发给服务器,服务器直接执行即可。

        若从控制台输入数据,在 sql 语句中 values(?,?...) 用到 ? 占位符,通过 preparedStatement 对象来设置值来对应 sql 语句中 ?的符号。

代码如下:

    public static void main(String[] args) throws SQLException {DataSource dataSource = new MysqlDataSource();((MysqlDataSource)dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/db01?characterEncoding=utf8&useSSL=false");((MysqlDataSource) dataSource).setUser("root");((MysqlDataSource) dataSource).setPassword("123456");Connection connection = dataSource.getConnection();Scanner scanner = new Scanner(System.in);String name = scanner.next();int age = scanner.nextInt();String sql = "insert into student values(?,?)";PreparedStatement preparedStatement = connection.prepareStatement(sql);preparedStatement.setString(1,name);preparedStatement.setInt(2,age);int n = preparedStatement.executeUpdate();System.out.println(n);preparedStatement.close();connection.close();}

        2.5 执行 SQL 语句

        执行 SQL 语句,把刚才解析好的语句发给数据库服务器。可以通过 preparedStatement 对象的两个方法将 SQL 语句发送给服务器:

        1)executeUpdate():insert 、update 、delete 操作统一都是用 executeUpdate() 方法发送请求给服务器。执行这个方法,就会在内部,给数据库服务器发起请求,请求中就是包含了解析后的 sql ,等待数据库执行 sql ,返回响应,获取到返回值。这个返回值试一个 int 类型,表示这个操作影响了多少行数据。

代码如下:

        //4.0 发送已经解析好的sql语句到数据库服务器中int n = preparedStatement.executeUpdate();System.out.println(n);

        2)executeQuery():针对 select 操作使用的方法,将解析后的 sql 发送给服务器,返回响应是一个结果集合。

遍历结果集合:通过 resultSet.next() 作为判断是否为空条件,通过 resultSet.getInt("列名")来获取整型数据,比如 resultSet.getString("列名") 获取字符串等等类型的数据。

代码如下:

        //得到的是一个结果集ResultSet resultSet = preparedStatement1.executeQuery();while(resultSet.next()){String name = resultSet.getString("name");int age = resultSet.getInt("age");System.out.println(age + " " + name );}

        2.6 释放资源

        在完成数据库操作后,及时关闭数据库连接以释放资源。以上需要释放的资源有:preparedStatement、connection 。

代码如下:

        preparedStatement.close();connection.close();

        3.0 完整代码

import com.mysql.cj.jdbc.MysqlDataSource;import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;public class demo {public static void main(String[] args) throws SQLException {//1.0 创建数据源DataSource dataSource = new MysqlDataSource();((MysqlDataSource)dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/db01?characterEncoding=utf8&useSSL=false");((MysqlDataSource) dataSource).setUser("root");((MysqlDataSource) dataSource).setPassword("123456");//2.0 与数据库建立联系Connection connection = dataSource.getConnection();// 3.0 创建SQL语句String sql = "insert into student values('张三三',14)";PreparedStatement preparedStatement = connection.prepareStatement(sql);String sql1 = "select * from student";PreparedStatement preparedStatement1 = connection.prepareStatement(sql1);//4.0 发送已经解析好的sql语句到数据库服务器中int n = preparedStatement.executeUpdate();System.out.println(n);//得到的是一个结果集ResultSet resultSet = preparedStatement1.executeQuery();while(resultSet.next()){String name = resultSet.getString("name");int age = resultSet.getInt("age");System.out.println(age + " " + name );}//5.0 释放资源preparedStatement.close();connection.close();}
}

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

FFmpeg 常用命令汇总

​​​​​​经常用到ffmpeg做一些视频数据的处理转换等,用来做测试,今天总结了一下,参考了网上部分朋友的经验,一起在这里汇总了一下。 1、ffmpeg使用语法 命令格式: ffmpeg -i [输入文件名] [参数选项] -f [格…

Word粘贴时出现“运行时错误53,文件未找到:MathPage.WLL“的解决方案

在安装完MathType后,打开word复制粘贴时报错“运行时错误53,文件未找到:MathPage.WLL” 首先确定自己电脑的位数(这里默认32位) 右击MathType桌面图标,点击“打开文件所在位置”, 然后分别找到MathPage.W…

ISIS接口认证实验简述

默认情况下,ISIS接口认证通过在ISIS协议数据单元(PDU)中添加认证字段,例如:一个密钥或密码,用于验证发送方的身份。 ISIS接口认证防止未经授权的设备加入到网络中,并确保邻居之间的通信是可信的…

SpingBoot集成Rabbitmq及Docker部署

文章目录 介绍RabbitMQ的特点Rabbitmq术语消息发布接收流程 Docker部署管理界面说明Overview: 这个页面显示了RabbitMQ服务器的一般信息,例如集群节点的名字、状态、运行时间等。Connections: 在这里,可以查看、管理和关闭当前所有的TCP连接。Channels: …

多租户平台前端存储结构的选择

下图来源于cookie、localStorage 和 sessionStorage的区别及应用实例 既然localstorage无有效期,关闭浏览器还存在,那么用来存储用户的身份信息并不是太合适,先看一下B站中localstorage都存在了啥,原来把我搜索的记录都存在了下来…

灯塔:CSS笔记(4)

伪类选择器: 1.作用与优势: 1.作用:根据元素在HTML中的结构关系查找元素 2.优势:减少对于HTML中类的依赖,有利于保持代码的整洁 3.场景:常用于查找某父级选择器中的子元素 2.选择器 选择器说明E:first-c…

重新认识BIO、NIO、IO多路复用、Select、Poll、Epollo它们之间的关系

目录 一、背景 二、名词理解 (1)BIO (2)NIO (3)IO多路复用 (4)Select、Poll、Epollo 三、他们之间的关系总结 一、背景 最近又在学习网络IO相关知识,对我们常说的…

可视化软件:第一原理计算/VASP + 结构预测/USPEX

分享一篇 VASPUSPEX 的可视化软件。 感谢论文的原作者! 主要内容 “流行的第一原理仿真代码 Vienna Ab initio Simulation Package (VASP) 和晶体结构预测 (CSP) 包、Universal Structure Predictor: Evolutionary Xtallography (USPEX) 已集成到 GDIS 可视化软件…

PWM驱动舵机

PWM驱动舵机 接线图 程序结构图: pwm.c部分代码 #include "stm32f10x.h" // Device headervoid PWM_Init(void){// 开启时钟,这里TIM2是通用寄存器RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE);// GPIO初始化代…

如何在Windows系统搭建Emby影音平台并实现远程访问本地文件【内网穿透】

文章目录 1.前言2. Emby网站搭建2.1. Emby下载和安装2.2 Emby网页测试 3. 本地网页发布3.1 注册并安装cpolar内网穿透3.2 Cpolar云端设置3.3 Cpolar内网穿透本地设置 4.公网访问测试5.结语 1.前言 在现代五花八门的网络应用场景中,观看视频绝对是主力应用场景之一&…

计算机网络——物理层(数据交换方式)

计算机网络——数据交换方式 提高数据交换方式的必要性电路交换电路交换原理电路交换的阶段建立阶段通信阶段和连接拆除阶段 电路交换的优缺点报文交换什么是报文报文交换的阶段报文交换的优缺点 分组交换分组交换的阶段分组交换的优缺点 数据交换方式的选择数据报方式数据报方…

unity内存优化之AB包篇(微信小游戏)

1.搭建资源服务器使用(HFS软件(https://www.pianshen.com/article/54621708008/)) using System.Collections; using System.Collections.Generic; using UnityEngine;using System;public class Singleton<T> where T : class, new() {private static readonly Lazy<…