用Java操作MySQL数据库
新建Maven项目
创建Maven项目
添加依赖
在pom.xml的标签里加上下面的内容
如果是MySQL 5.8那么的版本号是5.x.x, 例如5.1.49
如果是MySQL 8.0那么的版本号是8.x.x, 例如 8.0.28
<dependencies><!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.49</version></dependency></dependencies>
新建实体类
构建实体类, 类属性和表对应上, 方便来接收查询数据
举例
对于一个学生信息表
CREATE TABLE student(id BIGINT,`name` VARCHAR(100),sn BIGINT,email VARCHAR(100),classId BIGINT)
新建学生类
public class Student {private int id;private String name;private long sn;private String email;private int classId;//记得自己加上toString()方法,和每个属性的getter和Setter方法
}
连接数据库查询内容
import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;
import javax.sql.DataSource;
import java.sql.*;
import java.util.Scanner;public class Demo01_Connection {//先定义数据源对象, 待会用这个数据源操作数据库//先定义一个名字, 待会再具体实现private static DataSource dataSource = null;//定义自己数据库的各种属性, 方便全局修改// 数据库的用户名private static final String USER = "root";// 数据库的密码private static final String PASSWORD = "123456";// 数据库连接字符串(针对MySQL5) 本机数据库ip就是"localhost", 端口默认3306private static final String URL = "jdbc:mysql://数据库服务ip:端口号/数据库名?characterEncoding=utf-8&useSSL=false";// 如果是MySQL 8则是下面(mysql 8要加时区设置)//private static final String URL = "jdbc:mysql://数据库服务ip:端口号/数据库名?characterEncoding=utf8&useSSL=false&serverTimezone=Asia/Shanghai";public static void main(String[] args) {// 1. 初化始数据源,待会赋给上面定义的数据源MysqlDataSource myDataSource = new MysqlDataSource();// 2. 设置连接的参数myDataSource.setURL(URL);myDataSource.setUser(USER);myDataSource.setPassword(PASSWORD);// 3. 把构建好的Mysql数据源赋值给JDBC中的datasourcedataSource = myDataSource;//下面三个声明在try{}之外,方便finally也能识别Connection connection = null;PreparedStatement statement = null;ResultSet resultSet = null;try{//通过数据源获取一个数据库连接connection = dataSource.getConnection();//接收用户输入的值System.out.print("请输入姓名:");Scanner scanner = new Scanner(System.in);String sn = scanner.next();//定义SQL语句String sql = "select * from student where name = ?";// 获取一个预处理对象statement = connection.prepareStatement(sql);// 处理占位符的值,要匹配上类型,参数1代表第几个占位符,后者表示要被替换的内容statement.setString(1, sn);// 4. 执行SQLresultSet = statement.executeQuery();if (resultSet.next()) { //如果读取到了内容// 创建表示结果的JAVA对象Student student = new Student();student.setId(resultSet.getInt(1));student.setName(resultSet.getString(2));student.setSn(resultSet.getLong(3));student.setEmail(resultSet.getString(4));student.setClassId(resultSet.getInt(5));System.out.println(student);}}catch (SQLException e){e.printStackTrace();}finally {// 依次关闭资源,从后往前关if (resultSet != null) {try {resultSet.close();} catch (SQLException e) {e.printStackTrace();}}if (statement != null) {try {statement.close();} catch (SQLException e) {e.printStackTrace();}}if (connection != null) {try {connection.close();} catch (SQLException e) {e.printStackTrace();}}}}
}
将一系列操作封装成工具类
import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;
import javax.sql.DataSource;
import java.sql.*;public class DBUtil {// 先定义一个数据源对象private static DataSource dataSource = null;// 数据库的用户名private static final String USER = "root";// 数据库的密码private static final String PASSWORD = "123456";// 数据库连接字符串private static final String URL = "jdbc:mysql://127.0.0.1:3306/java78?characterEncoding=utf-8&useSSL=false";static {// 初始化数据源,类加载时运行MysqlDataSource mysqlDataSource = new MysqlDataSource();mysqlDataSource.setURL(URL);mysqlDataSource.setUser(USER);mysqlDataSource.setPassword(PASSWORD);dataSource = mysqlDataSource;}// 用private 修饰构造方法,使外部不能new 这个类的对象private DBUtil() {}//获取数据库连接public static Connection getConnection () throws SQLException {return dataSource.getConnection();}//关闭对象并释放资源public static void close (ResultSet resultSet, PreparedStatement statement, Connection connection) {// 依次关闭对象,并释放资源if (resultSet != null) {try {resultSet.close();} catch (SQLException e) {e.printStackTrace();}}if (statement != null) {try {statement.close();} catch (SQLException e) {e.printStackTrace();}}if (connection != null) {try {connection.close();} catch (SQLException e) {e.printStackTrace();}}}
}
使用方法
省略了设置数据源参数和关闭数据源的操作
public class Main{public static void main(String[] args) {//声明三个对象Connection connection = null;PreparedStatement statement = null;ResultSet resultSet = null;try {// 1. 创建数据源并获取数据库连接connection = DBUtil.getConnection();// 2. 构造SQL语句String sql = "select id, name, sn, email, classId from student order by id ASC";// 使用SQL预处理对象处理SQLstatement = connection.prepareStatement(sql);// 3. 执行SQL并获取结果,如果是结果集把结果集转成java对象resultSet = statement.executeQuery();// 遍历结果集,处理查询到数据while (resultSet.next()) {Student student = new Student();student.setId(resultSet.getInt(1));student.setName(resultSet.getString(2));student.setSn(resultSet.getLong(3));student.setEmail(resultSet.getString(4));student.setClassId(resultSet.getInt(5));}// 打印结果System.out.println(student);} catch (SQLException e) {e.printStackTrace();} finally {// 4. 释放资源DBUtil.close(resultSet, statement, connection);}}
}
接收多个查询结果
import java.sql.*;
import java.util.ArrayList;
import java.util.List;public class Demo02_SelectAll {public static void main(String[] args) {// 查询到的所有学生信息放在List里List<Student> students = null;Connection connection = null;PreparedStatement statement = null;ResultSet resultSet = null;try {// 1. 创建数据源并获取数据库连接connection = DBUtil.getConnection();// 2. 构造SQL语句String sql = "select id, name, sn, email, classId from student order by id ASC";// 使用SQL预处理对象处理SQLstatement = connection.prepareStatement(sql);// 3. 执行SQL并获取结果,如果是结果集把结果集转成java对象resultSet = statement.executeQuery();// 遍历结果集,处理查询到数据while (resultSet.next()) {// 如果List为空则创建if (students == null) {students = new ArrayList<>();}// 解析结果集并封装成Student对象Student student = new Student();student.setId(resultSet.getInt(1));student.setName(resultSet.getString(2));student.setSn(resultSet.getLong(3));student.setEmail(resultSet.getString(4));student.setClassId(resultSet.getInt(5));// 加入到集合中students.add(student);}// 打印结果System.out.println(students);} catch (SQLException e) {e.printStackTrace();} finally {// 4. 释放资源DBUtil.close(resultSet, statement, connection);}}
}
数据更改
如果你想update, 那么把SQL语句即可, 原理是相同的,基本不用改Java代码. 例如改成
Update student set age=10 where name=?
查询时statement.executeQuery(), 设置是statement.executeUpdate()
import java.sql.*;
import java.util.Scanner;public class Demo03_Delete {public static void main(String[] args) {Connection connection = null;PreparedStatement statement = null;try {// 1. 获取数据库连接connection = DBUtil.getConnection();// 2. 构建SQLString sql = "delete from student where name = ?";// 接收用户的输入System.out.print("请输入要删除的同学姓名:");Scanner scanner = new Scanner(System.in);String name = scanner.next();// 3. 对SQL进行处理,并替换占位符statement = connection.prepareStatement(sql);//替换参数: 1代表第一个问号, name代表填入的数据statement.setString(1, name);// 4. 执行SQL并获取结果int row = statement.executeUpdate();if (row <= 0) {System.out.println("删除失败.");} else {System.out.println("删除成功");}} catch (SQLException e) {e.printStackTrace();} finally {// 释放资源DBUtil.close(null, statement, connection);}}
}
插入数据
import java.sql.*;
import java.util.Scanner;public class Demo04_Insert {public static void main(String[] args) {Connection connection = null;PreparedStatement statement = null;try {// 1. 获取数据库连接connection = DBUtil.getConnection();// 2. 构建SQLString sql = "insert into student values (?, ?, ?, ?, ?)";// 接收用户的输入Scanner scanner = new Scanner(System.in);System.out.print("请输入要添加的同学Id:");int id = scanner.nextInt();// 姓名System.out.print("请输入学生的姓名:");String name = scanner.next();// 学号System.out.print("请输入学生的学号->");long sn = scanner.nextLong();// 邮箱System.out.print("请输入学生的邮箱->");String email = scanner.next();// 班级编号System.out.print("请输入学生的班级编号->");int classId = scanner.nextInt();// 3. 对SQL进行处理statement = connection.prepareStatement(sql);// 替换占位符statement.setInt(1, id);statement.setString(2, name);statement.setLong(3, sn);statement.setString(4, email);statement.setInt(5, classId);// 4. 执行SQL并获取结果int row = statement.executeUpdate();if (row <= 0) {System.out.println("添加失败.");} else {System.out.println("添加成功");}} catch (SQLException e) {e.printStackTrace();} finally {// 释放资源DBUtil.close(null, statement, connection);}}
}
相关文章:
用Java操作MySQL数据库
新建Maven项目 创建Maven项目 添加依赖 在pom.xml的标签里加上下面的内容 如果是MySQL 5.8那么的版本号是5.x.x, 例如5.1.49 如果是MySQL 8.0那么的版本号是8.x.x, 例如 8.0.28 <dependencies><!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java …...
SpringBoot启动报错:java: 无法访问org.springframework.boot.SpringApplication
报错原因:jdk 1.8版本与SpringBoot 3.1.2版本不匹配 解决方案:将SpringBoot版本降到2系列版本(例如2.5.4)。如下图: 修改版本后切记刷新Meavn依赖 然后重新启动即可成功。如下图:...
Vue3 setup语法糖 解决富文本编辑器上传图片64位码过长问题 quill-image-extend-module
引言: 富文本编辑器传图片会解码成64位,非常长导致数据库会报错第一种方法:将数据库类型改成 mediumtext第二种办法:本文中的方法 说明,本周文所用语法糖为Vue3 setup语法,即<script setup> 思路 拦…...
百度坐标(BD09)、国测局坐标(火星坐标,GCJ02)、和WGS84坐标系之间的转换
<!DOCTYPE html> <html><head><meta charset="UTF-8"><title></title></head><body><script>/*** * 百度坐标(BD09)、国测局坐标(火星坐标,GCJ02)、和WGS84坐标系之间的转换*///定义一些常量var x_PI = …...
论文浅尝 | CI4MRC:基于因果推断去除机器阅读理解中的名字偏差
笔记整理:朱珈徵,天津大学硕士,研究方向:问答 链接:https://aclanthology.org/2023.findings-acl.812/ 动机 机器阅读理解(Machine Reading Comprehension,MRC)是根据给定的文章回答…...
【校招VIP】测试计划之黑盒测试白盒测试
考点介绍: 黑盒测试&白盒测试是大厂和三四线公司校招的必考点。黑盒是以结果说话,白盒往往需要理解实现逻辑。现在商业项目的接口测试往往以白盒为主,也就是需要测试同学自己观察和修改数据库的值进行用例的测试。 但是无论采用哪种测试方…...
学习笔记整理-JS-01-语法与变量
文章目录 一、语法与变量1. 初识JavaScript2. JavaScript的历史3. JavaScript与ECMAScript的关系4. JavaScript的体系5. JavaScript的语言风格和特性 二、语法1. JavaScript的书写位置2. 认识输出语句3. REPL环境,交互式解析器4. 变量是什么5. 重点内容 一、语法与变…...
PHP之PHPExcel
include PHPExcel.php; include PHPExcel/Writer/Excel2007.php; //或者include PHPExcel/Writer/Excel5.php; 用于输出.xls的 //创建一个excel $objPHPExcel new PHPExcel(); // 输出Excel表格到浏览器下载 header(Content-Type: application/vnd.ms-excel); header(Content-…...
Redis系列(一):深入了解Redis数据类型和底层数据结构
Redis有以下几种常用的数据类型: redis数据是如何组织的 为了实现从键到值的快速访问,Redis 使用了一个哈希表来保存所有键值对。 Redis全局哈希表(Global Hash Table)是指在Redis数据库内部用于存储所有键值对的主要数据结构。…...
javaScript:如何获取html中的元素对象
目录 前言: 方法 1.通过id获取元素 2.通过标签名获取元素 3.通过类名class获取元素 获取body的方法 1.document.getElementsByTagName(body)[0] 2.document.body 相关代码 前言: 通过获取HTML中的元素对象,JavaScript可以对网页进行动…...
面试总结-webpack/git
说说你对webpack的理解 webpack 是一个静态模块打包器,整个打包过程就像是一条生产线,把资源从入口放进去,经过一系列的加工(loader),最终转换成我们想要的结果,整个加工过程还会有监控&#x…...
深入解析美颜SDK:算法、效果与实现
在当今数字化社会中,图像处理和美化技术已经成为了许多应用领域的重要组成部分,尤其在视频直播领域,美颜技术更是无处不在。直播美颜SDK作为一种集成的软件工具包,为开发者和应用提供了强大的美颜功能。 一、算法原理 磨皮算法…...
ChatGPT Plus和ChatGPT对比
模型规模更大,参数数量超过6万亿,比ChatGPT大很多训练数据更丰富,包括不同语言、领域和类型的数据语言理解和生成能力更强,能够更准确地理解和生成文本可解释性和可控性更好,支持更多的调参和控制参数,生成…...
计算机网络 运输层 TCP连接建立、释放
三报文而不是两报文...
npm run xxx 的时候发生了什么?(以npm run dev举例说明)
文章目录 一、去package.json寻找scripts对应的命令二、去node_modules寻找vue-cli-service三、从package-lock.json获取.bin的软链接1. bin目录下的那些软连接存在于项目最外层的package-lock.json文件中。2.vue-cli-service文件的作用3.npm install 的作用 总结 一、去packag…...
图解结构体大小和位域例子
struct A {short a; char b; int c : 1; char d : 4; short e : 7; }; 备注:蓝色:表示占一个符号位空间红色:表示补齐其他颜色:实际最大值所占空间 (1)图解例1 st…...
游戏行业实战案例 5 :玩家在线分布
【面试题】某游戏数据后台设有“登录日志”和“登出日志”两张表。 「登录日志」记录各玩家的登录时间和登录时的角色等级。 「登出日志」记录各玩家的登出时间和登出时的角色等级。 其中,「角色 id 」字段唯一识别玩家。 游戏开服前两天( 2022-08-13 至…...
TypeScript 关于对【泛型】的定义使用解读
目录 概念导读泛型函数多个泛型参数泛型约束泛型别名泛型接口泛型类总结: 概念导读 泛型(Generics)是指在定义函数、接口或类的时候,不预先指定具体的类型,而在使用的时候再指定类型的一种特性。使用泛型 可以复用类型…...
盛元广通食品药品检验检测实验室LIMS系统
随着食品与制药行业法规标准的日益提高和国家两化融合的不断推进,为保障检验工作的客观、公正及科学性,确保制药企业对于生产、实验室、物流、管理的信息化和智能化需求越来越明确,为确保新品可及时得到科学准确的检测检验结果,盛…...
【数据结构】-- 栈和队列
🐇 🔥博客主页: 云曦 📋系列专栏:数据结构 💨吾生也有涯,而知也无涯 💛 感谢大家👍点赞 😋关注📝评论 文章目录 前言一、栈📙1.1 栈…...
设计模式和设计原则回顾
设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...
【Java学习笔记】Arrays类
Arrays 类 1. 导入包:import java.util.Arrays 2. 常用方法一览表 方法描述Arrays.toString()返回数组的字符串形式Arrays.sort()排序(自然排序和定制排序)Arrays.binarySearch()通过二分搜索法进行查找(前提:数组是…...
在rocky linux 9.5上在线安装 docker
前面是指南,后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...
STM32+rt-thread判断是否联网
一、根据NETDEV_FLAG_INTERNET_UP位判断 static bool is_conncected(void) {struct netdev *dev RT_NULL;dev netdev_get_first_by_flags(NETDEV_FLAG_INTERNET_UP);if (dev RT_NULL){printf("wait netdev internet up...");return false;}else{printf("loc…...
【SQL学习笔记1】增删改查+多表连接全解析(内附SQL免费在线练习工具)
可以使用Sqliteviz这个网站免费编写sql语句,它能够让用户直接在浏览器内练习SQL的语法,不需要安装任何软件。 链接如下: sqliteviz 注意: 在转写SQL语法时,关键字之间有一个特定的顺序,这个顺序会影响到…...
2021-03-15 iview一些问题
1.iview 在使用tree组件时,发现没有set类的方法,只有get,那么要改变tree值,只能遍历treeData,递归修改treeData的checked,发现无法更改,原因在于check模式下,子元素的勾选状态跟父节…...
Neo4j 集群管理:原理、技术与最佳实践深度解析
Neo4j 的集群技术是其企业级高可用性、可扩展性和容错能力的核心。通过深入分析官方文档,本文将系统阐述其集群管理的核心原理、关键技术、实用技巧和行业最佳实践。 Neo4j 的 Causal Clustering 架构提供了一个强大而灵活的基石,用于构建高可用、可扩展且一致的图数据库服务…...
GitHub 趋势日报 (2025年06月08日)
📊 由 TrendForge 系统生成 | 🌐 https://trendforge.devlive.org/ 🌐 本日报中的项目描述已自动翻译为中文 📈 今日获星趋势图 今日获星趋势图 884 cognee 566 dify 414 HumanSystemOptimization 414 omni-tools 321 note-gen …...
Pinocchio 库详解及其在足式机器人上的应用
Pinocchio 库详解及其在足式机器人上的应用 Pinocchio (Pinocchio is not only a nose) 是一个开源的 C 库,专门用于快速计算机器人模型的正向运动学、逆向运动学、雅可比矩阵、动力学和动力学导数。它主要关注效率和准确性,并提供了一个通用的框架&…...
基于TurtleBot3在Gazebo地图实现机器人远程控制
1. TurtleBot3环境配置 # 下载TurtleBot3核心包 mkdir -p ~/catkin_ws/src cd ~/catkin_ws/src git clone -b noetic-devel https://github.com/ROBOTIS-GIT/turtlebot3.git git clone -b noetic https://github.com/ROBOTIS-GIT/turtlebot3_msgs.git git clone -b noetic-dev…...
