[MySQL数据库] Java的JDBC编程(MySQL数据库基础操作完结)

🌸个人主页:https://blog.csdn.net/2301_80050796?spm=1000.2115.3001.5343
🏵️热门专栏:🍕 Collection与数据结构 (91平均质量分)https://blog.csdn.net/2301_80050796/category_12621348.html?spm=1001.2014.3001.5482
🧀Java EE(94平均质量分) https://blog.csdn.net/2301_80050796/category_12643370.html?spm=1001.2014.3001.5482
🍭MySql数据库(93平均质量分)https://blog.csdn.net/2301_80050796/category_12629890.html?spm=1001.2014.3001.5482
感谢点赞与关注~~~
在这里插入图片描述

目录

  • 1. Java的数据库编程-----JDBC
  • 2. JDBC工作原理
    • 2.1 JDBC的访问数据库层次结构:
    • 2.2 JDBC的优势:
  • 3. JDBC的使用
    • 3.1 导入JDBC的.jar文件
    • 3.2 JDBC编程基本步骤

1. Java的数据库编程-----JDBC

在数据库的编程中,由于各个数据库的编程方式各不相同,所以在市场上流行着很多数据库,这就成为了程序员们非常头疼的一个点,于是这时候就需要一个人来统一天下,于是Java老大哥便站了出来.每一种数据库都需要给Java语言提供一个API,把原生的API进行封装,按照Java的规定统一过来.JDBC,即Java Database Connectivity,java数据库连接.是一种用于执行SQL语句的Java API,它是Java中的数据库连接规范.这个API由java.sql.*,javax.sql.*包中的一些类和接口组成,它为Java开发人员操作数据库提供了一个标准的API,可以为多种关系数据库提供统一访问.

[注释] 什么是API: API(Application Progromming interface 应用程序编程接口),就可以理解为一组"类",或者是"接口",有的库API非常多,就形成了SDK(软件开发工具包),例如:jdk.

2. JDBC工作原理

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

2.1 JDBC的访问数据库层次结构:

在这里插入图片描述
这里的数据库JDBC驱动程序是数据库提供的"接口转换程序",通过驱动程序把数据库原生的应用程序编程接口和Java的应用程序编程接口转接过来,就可以理解为我们常用的转接头.

2.2 JDBC的优势:

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

3. JDBC的使用

首先我们需要下载JavaJDBC编程的第三方库,把Java和MySQL建立联系.这里我们从"中央仓库"中即可下载.
JDBC下载地址:https://mvnrepository.com/artifact/mysql/mysql-connector-java/5.1.49
下载好了之后,我们就会得到一个后缀名为.jar的文件.此时我们就可以建立连接了.

3.1 导入JDBC的.jar文件

  • 首先我们新建一个项目,在根目录下新建一个目录.命名为lib.
    在这里插入图片描述
  • 之后我们把.jar文件导入该目录中.
    在这里插入图片描述
  • 之后右键.jar文件,选择"添加为库".
    在这里插入图片描述

3.2 JDBC编程基本步骤

在导入成功之后,我们就可以开始编程了.

  • 首先创建数据源
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("qwe123524");

第一行就是让数据库厂商与JDBC进行对接,就是让数据库厂商实现JDBC中提供的提供的interface,进一步实现其中约定好的抽象方法.
下一行就是固定的写法,直接照抄.
之后就是输入用户名,用户名默认为"root".
下一行就是该用户登录数据库的密码.
[注意] 在与数据库建立连接的时候,使用的是向上转型的方式,在使用数据源中的方法的时候,再向下转回来.之所以要这样做,是为了根便于代码与数据库之间==“解耦合”(低耦合)==,万一哪天要换数据库的时候,改动成本就会降低.

一种写代码的追求:高内聚,低耦合
高内聚就是实现某个功能的时候,如果这个功能相关的代码.,是集中放到一起的,就认为是"高内聚".如果是散落在项目的各个文件,就认为是"低内聚".
低耦合就是在写代码的时候,会有很多模块,如果一个模块的代码修改之后,对其他的模块影响很小,就叫低耦合.

  • 客户端和数据库服务器进行连接
Connection connection = dataSource.getConnection();

在进行client和server通信的时候,常见的方式有两种模式:有连接和无连接.
1. 有连接:(JDBC这里就是有连接)比如我们在打电话的时候,我们需要先拨号---->连接---->接听三部.
2. 无连接:比如我们我们发微信,不需要用户接听,就可以直接发过去.

  • 构造一个操作数据库的sql语言
 System.out.println("姓名:");Scanner scanner = new Scanner(System.in);System.out.println("职位类型:");Scanner scanner1 = new Scanner(System.in);System.out.println("薪水:");Scanner scanner2 = new Scanner(System.in);String name = scanner.next();String role = scanner1.next();int salary = scanner2.nextInt();String sql = "insert into emp values(null,"+name+","+role+","+salary+")";

这里我们构建一个在emp表中插入员工的字符串.

PreparedStatement preparedStatement = connection.prepareStatement(sql);

这里就相当于告诉编译器,该字符串是一个可执行的sql语句.
这里也可以使用Statement类来进行接收,但是我们最好用prepareStatement,是因为我们发射红一个字符串带server上的时候,先要判定是否合法,Statement接收的写法是在server上进行验证.而PrepareStatement的写法是在client上进行验证,这样就可以有效避免不合法的语句对数据库的影响.

  • 执行sql
    在构建好sql语句之后,我们就可以对prepareStatement语句进行执行了.
int n = preparedStatement.executeUpdate();
System.out.println(n);

由于是插入操作,所以涉及到对数据库的更新.所以execute的后缀就是update.如果是查询操作的话,不涉及到数据库的更新,所以后缀就是Query.
executeUpdate方法会有返回值,这里的返回值就表示的是表中的几行数据有了改变.

执行这个方法之后,就会在内部给数据库的server发送一个请求,请求内部就包含了prepareStatement解析之后的sql语句,数据库在执行sql语句之后就会返回响应,获取响应之后就会通过返回值体现出来.

这是我们看到表emp中有以下数据:
在这里插入图片描述
我们执行该sql语句,插入"王十三,数据库运维,12000"
在这里插入图片描述
我们看到数据库发生了改变.
在这里插入图片描述

  • 收尾工作-----关闭资源.
preparedStatement.close();
connection.close();

为什么要关闭资源?是因为编程中设计到的"有限资源",不仅仅有内存如果是内存资源,JVM可自动回收,但是其他的,JVM就无能为力,需要手动释放.
[注意] 创建顺序与释放顺序相反,就像我们平时穿衣服和脱衣服的顺序一样.

  • 最终代码
import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;
import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.Scanner;public class Demo {public static void main(String[] args) throws SQLException {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("qwe123524");Connection connection = dataSource.getConnection();System.out.println("姓名:");Scanner scanner = new Scanner(System.in);System.out.println("职位类型:");Scanner scanner1 = new Scanner(System.in);System.out.println("薪水:");Scanner scanner2 = new Scanner(System.in);String name = scanner.next();String role = scanner1.next();int salary = scanner2.nextInt();String sql = "insert into emp values(null,"+name+","+role+","+salary+")";PreparedStatement preparedStatement = connection.prepareStatement(sql);int n = preparedStatement.executeUpdate();System.out.println(n);preparedStatement.close();connection.close();}
}

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

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

相关文章

【北京迅为】《iTOP-3588开发板快速烧写手册》-第8章 TF启动

RK3588是一款低功耗、高性能的处理器,适用于基于arm的PC和Edge计算设备、个人移动互联网设备等数字多媒体应用,RK3588支持8K视频编解码,内置GPU可以完全兼容OpenGLES 1.1、2.0和3.2。RK3588引入了新一代完全基于硬件的最大4800万像素ISP&…

C/C++ 初级球球大作战练手

效果演示&#xff1a; https://live.csdn.net/v/385490 游戏初始化 #include <stdbool.h> #include<stdio.h> #include<stdlib.h> #include<time.h> #include<graphics.h> #include <algorithm> #include<math.h> #include<mmsy…

java多线程编码应用1——java多线程CompletableFuture使用技巧

在实际项目开发过程中&#xff0c;大部分程序的执行顺序都是按照代码编写的先后顺序&#xff0c;依次从上往下挨个执行的&#xff0c;但是对于统计或者批量操作数据时&#xff0c;是否有更好的方案呢&#xff1f;这时候就可以考虑使用多线程编程&#xff0c;异步并行执行多个任…

【MATLAB画图】如何绘制图像坐标系

首先我们需要图像坐标轴的原点在左上角&#xff1a; set(gca,ydir,reverse,xaxislocation,top); 然后我们需要坐标轴上加上箭头 quiver(0, 0, 0, 520); % 在(x1, y1)处绘制一个箭头&#xff0c;其方向和长度由(dx, dy)确定 quiver(0, 0, 700, 0); % 在(x1, y1)处绘制一个箭头…

英语新概念2-回译法-lesson13

The Greenwood Boys 绿林少年是一组流行歌手们。现在他们正在参观城市里的所有公园&#xff0c;他们明天就要到这。他们将坐火车到并且大多数小镇上的年轻人将要欢迎他们&#xff0c;明天晚上他们将要在工人俱乐部唱歌。绿林少年将在这待五天&#xff0c;在这期间&#xff0c;…

flowable一对并发网关跳转的分析

更多ruoyi-nbcio功能请看演示系统 gitee源代码地址 前后端代码&#xff1a; https://gitee.com/nbacheng/ruoyi-nbcio 演示地址&#xff1a;RuoYi-Nbcio后台管理系统 http://218.75.87.38:9666/ 更多nbcio-boot功能请看演示系统 gitee源代码地址 后端代码&#xff1a; h…

前端面试题大合集3----网络篇

目录 一、Http协议详解&#xff0c;http请求方式&#xff0c;http状态码 Http协议详解&#xff1a; http请求方式&#xff1a; http状态码&#xff1a; 常用的状态码&#xff1a; 其他常用状态码&#xff1a; 二、Http常见请求方式 三、Http协议与TCP协议的区别和联系 …

【STM32G474】利用Cpp编写STM32代码后,Cubemx修改配置后代码报错147个error,如何处理?

问题描述 打开Cubemx&#xff0c;添加TIM7用于定时器精准延时&#xff0c;生成代码后&#xff0c;Keil提示有147个error。 之前是Cubemx是没有问题的&#xff0c;是利用Cpp编写stm32&#xff08;将Keil改为Version6&#xff09;后才导致Cubemx配置失败&#xff1a; debug成功…

Mybatis进阶2

Mybatis进阶1-CSDN博客 Mybatis入门-CSDN博客 Mybatis入门2-CSDN博客 我们接下来要学习Mybatis的高级查询 我们先在数据库中准备我们需要的数据表 teacher表 课程表&#xff1a;与教师表是一对多的关系&#xff0c;所以有一个外键字段 学生表 由于学生表和课程表是多对多的…

《Python编程从入门到实践》day22

# 昨日知识点回顾 方法重构、驾驶飞船左右移动、全屏显示 飞船不移动解决&#xff0c;问题出在移动变量x更新 # Ship.pysnipdef update(self):"""根据移动标志调整飞船的位置"""# 更新飞船而不是rect对象的x值# 如果飞船右移的标志和飞船外接…

射频无源器件之电桥

一. 电桥的定义及作用 电桥主要用于实现微波大功率功放系统的功率合成分配,信号采集等功能,被广泛应用于中国及全球4G/5G基站、5G网络覆盖、北斗导航天线、车载高精度导航(无人驾驶)天线等。可将信号分成有相位差的两路,90度电桥相位差90,180度电桥相位差180。 常说的3d…

Redis学习2——SpringBoot整合Redis,Redis工具类

依赖和配置 pom.xml SpringBoot整合Redis&#xff0c;需要引入spring-boot-starter-data-redis依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency>当…

stm32_RTC_2_HAL——stm32CudeMX

介绍 RTC&#xff08;实时时钟&#xff09;不仅仅提供计数功能&#xff0c;它是一个完整的时钟和日历模块&#xff0c;用于提供日期和时间信息。RTC 能够提供年、月、日、星期、时、分、秒等时间信息&#xff0c;并且通常具有闹钟功能&#xff0c;可以用于定时唤醒或触发事件。…

C++学习第十二天(继承)

1、继承的概念以及定义 继承的概念 继承机制是面向对象程序设计使代码可以复用的最重要的手段&#xff0c;它允许程序员在保持原有类特性的基础上进行拓展&#xff0c;增加功能&#xff0c;这样产生新的类&#xff0c;称派生类。继承呈现了面向对象程序设计的层次结构&#x…

STM32F103学习笔记 | 报错界面及解决方案 | 1.keil5中文注释的横竖(正与斜)问题

文章目录 一、报错界面二、解决方案参考文献 一、报错界面 二、解决方案 打开设置 在打开的设置选项卡中&#xff0c;图中Font显示的是这个软件当前设置的字体&#xff0c;可以看到字体是仿宋&#xff0c;这就是问题出现的原因&#xff0c;将之改成没有的字体就行了。 可以看…

用FPGA+DAC输出“心”形波

1.前言 之前在做信号处理的时候整了一下活&#xff0c;用FPGADAC&#xff08;数模转换器&#xff09;&#xff0c;输出了一个爱心形状的波形&#xff0c;今天整理资料的时候偶然发现了他&#xff0c;现在把他分享出来。当时将DAC的输出接在示波器上显示如下图所示&#xff1a; …

Docker使用进阶篇

文章目录 1 前言2 使用Docker安装常用镜像示例2.1 Docker安装RabbitMQ2.2 Docker安装Nacos2.3 Docker安装xxl-job&#xff08;推荐该方式构建&#xff09;2.4 Docker安装redis2.5 Docker安装mysql 3 Docker自定义镜像3.1 Dockerfile的基本结构3.2 Dockerfile指令3.3 自定义JDK镜…

Flutter笔记:手动配置VSCode中Dart代码自动格式化

Flutter笔记 手动配置VSCode中Dart代码自动格式化 - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article:https://blog.csd…

数据结构学习——线性表、顺序表

1.线性表 线性表 &#xff08; linear list &#xff09; 是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使 用的数据结构&#xff0c;常见的线性表&#xff1a;顺序表、链表、栈、队列、字符串… 线性表在逻辑上是线性结构&#xff0c;也就说是连续的一…

在WPS表格(Excel)中,每10行增加一个特定的值

注&#xff1a;如下为WPS表格操作演示 例如1&#xff0d;15的数值是1&#xff0c;16-30就变为2&#xff0c;31-45就变为3&#xff0c;类推&#xff01; 1、在B1单元格输入一个起始值&#xff0c;B2单元格输入公式IF(MOD(ROW(),15)0,B11,B1) 然后鼠标放到B2单元格右下角小点处&…