JDBC、excute()、DriveManager、Connection、Statement、自建JDBC工具类、占位符

DAY19.2 Java核心基础

JDBC

JDBC:Java database Connectivity

JDBC是java程序连接各种数据库的组件

Mybatis就是基于JDBC的封装,是独立于数据库的管理系统,通用的SQL数据库存取和操作的公共接口

定义了一套标准,为访问 不同数据库提供了统一的途径

  • 导入对应数据库驱动jar
  • 面向JDBC接口编程

JDBC接口包含两部分

  • 面向应用的API,给开发者调用
  • 面向数据库的API,供开发厂商开发数据库驱动

JDBC API

供开发者调用的类,主要在java.sql和javax.sql包中

  • DriverManager 类
  • Connection 接口
  • Statement 接口
  • ResultSet 接口

DriverManager:管理不同的驱动

JDBC驱动:复制连接不同的数据库

JDBC的原理:

加载数据库驱动,java程序和Mysql的桥梁

获取connection连接,一次连接

创建Statement,由Connection生成,执行sql语句

ResultSet保持Statement执行后产生的结果

建立一次连接:

public static void main(String[] args) throws SQLException {// 在URL中添加时区参数 serverTimezone=Asia/ShanghaiString url = "jdbc:mysql://localhost:3306/mytest1?serverTimezone=Asia/Shanghai&useSSL=false";String user = "root";String password = "root";Connection connection = DriverManager.getConnection(url, user, password);System.out.println(connection);
}

加载驱动就是将 JDBC 所需要的驱动类加载到 JVM 中才能运行,通过类加载器进行加载,通过反射机制将该类加载进来

Class.forName(类名) 反射机制,获取运行时类,什么是运行时类?

Java 程序是由类组成的,运行时,会将 Java 所有的类添加到 JVM 内存中,并且每个类只有一份,保持在 JVM 内存中的类叫运行时类,JVM 根据运行时类创建不同的对象,Class.forName(类名) 用来加载运行时类的,将驱动程序添加到 JVM 内存中,程序才能访问。

每个类的作用:

DriveManager:驱动管理类,创建Connection,通过用户名,密码,URL进行校验,校验成功创建一个Connection对象

Connection:表示java程序和Mysql之间的一次连接

Statement:表示sql的执行者,复制执行SQL语句

增删改操作 excute():

public static void main(String[] args) throws SQLException {// 在URL中添加时区参数 serverTimezone=Asia/ShanghaiString url = "jdbc:mysql://localhost:3306/mytest1?serverTimezone=Asia/Shanghai&useSSL=false";String user = "root";String password = "root";Connection connection = DriverManager.getConnection(url, user, password);System.out.println(connection);System.out.println("连接成功");// 定义sql// 增加String insertSql="insert into users(name,gender,score) values('小明','男',90)";// 删除String deleteSql="delete from users where name ='小明'";// 修改String updateSql="update users set name='述雾' where name = 'c'";// 执行sqlPreparedStatement preparedStatement = connection.prepareStatement(insertSql);boolean execute = preparedStatement.execute();System.out.println(execute);preparedStatement.close();preparedStatement = connection.prepareStatement(deleteSql);preparedStatement.execute();preparedStatement = connection.prepareStatement(updateSql);preparedStatement.execute();connection.close();preparedStatement.close();
}

excute():负责执行增 删 改方法

返回的结果是return rs != null && rs.hasRows();,判断是否为查询语句,rs != null表示是否有该对象,rs.hasRows()表示是否有值

executeQuery:负责执行查询方法,返回值 ResultSet,集合,查询肯定要返回查到的数据

返回的结果是一个ResultSet

通过ResultSet的next方法可以取出每一行的值

ResultSet resultSet = preparedStatement.executeQuery();
System.out.println(resultSet.getMetaData().getColumnCount());
while (resultSet.next()){// 方法一
//    String name = resultSet.getString("name");
//    String gender = resultSet.getString("gender");
//    double score = resultSet.getDouble("score");// 方法2String name = resultSet.getString(1);String gender = resultSet.getString(2);double score = resultSet.getDouble(3);System.out.println(name+" "+gender+" "+score);
}

这样每次操作都需要创建Connection,然后创建Statement对象然后执行吗?这样不显得太麻烦了吗

我们可以创建一个工具类来获取Connection连接,一个创建多次使用嘛,然后还可以封装一些方法来更新数据库的字段值

比如创建一个JDBCUtil工具类

在创建的时候初始化该类,初始化Connection对象,然后在insertUsers写一个方法插入到users表中

public class JDBCUtil {public static final String URL = "jdbc:mysql://localhost:3306/mytest1?useSSL=true&serverTimezone=GMT%2B8";public static final String USER = "root";public static final String PASSWORD = "root";public static final String DRIVER = "com.mysql.cj.jdbc.Driver";private Connection connection = null;// 获取连接public void initConnection(){try {Class.forName(DRIVER);connection = DriverManager.getConnection(URL, USER, PASSWORD);System.out.println("连接成功");} catch (ClassNotFoundException e) {throw new RuntimeException(e);} catch (SQLException e) {throw new RuntimeException(e);}}public JDBCUtil(){initConnection();}// 关闭连接public void closeConnection(){if (connection != null){try {connection.close();System.out.println("关闭连接");} catch (SQLException e) {throw new RuntimeException(e);}}}// 插入到users表字段public void insertUsers(String name,String gender,Integer score){String sql = "insert into users(name,gender,score) values('"+name+"','"+gender+"',"+score+")";System.out.println(sql);PreparedStatement preparedStatement = null;try {preparedStatement = connection.prepareStatement(sql);preparedStatement.execute();System.out.println("插入成功");} catch (SQLException e) {throw new RuntimeException(e);} finally {try {preparedStatement.close();} catch (SQLException e) {throw new RuntimeException(e);}}}}

测试函数

public class Test {public static void main(String[] args) throws SQLException {JDBCUtil jdbcUtil = new JDBCUtil();jdbcUtil.insertUsers("张三","男",100);}
}

成功插入

image-20250329172528767

image-20250329172518102

但是有个问题就是这样写sql赋值的时候显得太麻烦了,我们可以用占位符来解决

 String sql = "insert into users(name,gender,score) values('"+name+"','"+gender+"',"+score+")";
String sql = "insert into users(name,gender,score) values(?,?,?)";
System.out.println(sql);
PreparedStatement preparedStatement = null;
try {preparedStatement = connection.prepareStatement(sql);preparedStatement.setString(1,name);preparedStatement.setString(2,gender);preparedStatement.setInt(3,score);preparedStatement.execute();System.out.println("插入成功");
} catch (SQLException e) {throw new RuntimeException(e);
} finally {try {preparedStatement.close();} catch (SQLException e) {throw new RuntimeException(e);}
}

用preparedStatement.setString(占位符的位置,赋值的参数);

根据参数的类型可以选择setString(),setInt,setDouble…来设置,这样就好写多了

下一篇我们来讲解更加高级通用的方法

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

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

相关文章

21天Python计划:函数简单介绍

文章目录 前言一、函数知识体系二、函数基础函数的定义和调用函数参数 三、函数对象、函数嵌套、名称空间与作用域、装饰器函数对象函数嵌套名称空间与作用域装饰器 四、迭代器、生成器、面向过程编程迭代器生成器面向过程编程 五、三元表达式、列表推导式、生成器表达式、递归…

污水处理厂人员定位方案-UWB免布线高精度定位

1. 方案概述 本方案采用免布线UWB基站与北斗卫星定位融合技术,结合UWBGNSS双模定位工卡,实现污水处理厂室内外人员高精度定位(亚米级)。系统通过低功耗4G传输数据,支持实时位置监控、电子围栏、聚集预警、轨迹回放等功…

无人机DSP处理器工作要点!

一、DSP处理器在无人机中的工作要点 1. 高效运算架构 哈佛结构:DSP采用程序与数据存储分离的哈佛结构,允许同时访问指令和数据,提升数据吞吐效率。 流水线技术:将指令分解为取指、译码、执行等多个阶段并行处理&#xff0c…

MySQL查询成本计算

对于如上SQL,只是因为查询字段不同,最终执行时选择的索引就不同,那么MySQL是如何决定选择使用哪个索引呢? 答案是MySQL会进行成本计算,对于各个场景查询进行成本预估,最终选择最优。 我们可以使用trace工具…

《K230 从熟悉到...》矩形检测

《K230 从熟悉到...》矩形检测 《庐山派 K230 从熟悉到...》矩形检测 矩形检测技术是一种广泛应用于电子图像处理的核心技术。它通过识别和分析图像中的矩形结构,为各种应用提供基础支持。从传统图像处理算法到现代深度学习技术,矩形检测的实现途径多种多…

python基础学习三(元组及字符串的使用)

文章目录 元组什么是元组元组的创建方式为什么要将元组设计成不可变序列元组的遍历集合集合的相关操作集合操作集合的数学操作集合生成式列表,字典,元组,集合总结 字符串字符串的驻留机制判断字符串的操作方法字符串的比较操作字符串的切片操…

Java基础-22-基本语法-实体类

实体类(Entity Class) 1. 什么是实体类? 实体类(Entity Class) 是 Java 中用于表示数据库表结构或业务对象的类。它通常包含属性(字段)和getter/setter 方法,用于存储和操作数据。…

Android 系统ContentProvider流程

一、ContentProvider初始化注册流程 源码查看路径:http://xrefandroid.com/android-11.0.0_r48/ 涉及到源码文件: /frameworks/base/core/java/android/content/ContentProvider.java 自定义ContentProvider需要继承该类,内部类Transport继承关系如下,实…

爬虫工程师分享自动批量化获取商品评论数据的方法有哪些?

在电商领域,商品评论数据对于商家了解产品口碑、洞悉用户需求,以及开展竞品分析等工作具有极其重要的价值。作为爬虫工程师,掌握自动批量化获取商品评论数据的方法,能极大提升数据收集效率。下面,我将分享一些实用的操…

Vue3组件事件用户信息卡练习

用户信息卡 题目要求 实现一个用户信息卡系统&#xff0c;包含以下功能&#xff1a; 1.父组件收集用户信息&#xff08;姓名、年龄、班级&#xff09; 2.子组件接收并展示用户信息卡片 3.添加基本的数据验证 <!DOCTYPE html> <html lang"en"> <h…

SpringBean模块(二)bean初始化(2)和容器初始化顺序的比较--引入ApplicationContextInitializer

前面介绍了获取容器可以让spring bean实现ApplicationContextAware&#xff0c;实际也是初始化执行了setApplicationContext接口&#xff0c; 初始化接口还可以借助一些注解或者spring bean的初始化方法&#xff0c;那么他们的执行顺序是什么样的呢&#xff1f; 一、验证&…

中小型企业网络的搭建

1.1 网络逻辑拓扑、布线方案的设计 1.1.1 网络设计依据 网络设计应遵循以下基本原则&#xff1a; 高效性&#xff1a;确保网络架构能够支持企业日常业务的高效运行。 可靠性&#xff1a;采用冗余设计&#xff0c;确保网络的高可用性&#xff0c;避免单点故障。 可扩展性…

angr基础学习

参考&#xff1a;angr AngrCTF_FITM/笔记/03/Angr_CTF从入门到精通&#xff08;三&#xff09;.md at master ZERO-A-ONE/AngrCTF_FITM angr_explore 00_angr_find IDA分析结果&#xff1a; 逻辑简单&#xff0c;输入&#xff0c;complex_function进行加密&#xff0c;加密…

软考-高级-系统架构设计师【考试备考资料下载】

计算机技术与软件专业技术资格&#xff08;水平&#xff09;考试是原中国计算机软件专业技术资格和水平考试的完善与发展。计算机技术与软件专业技术资格&#xff08;水平&#xff09;考试是由国家人力资源和社会保障部、工业和信息化部领导下的国家级考试。 计算机技术与软件专…

3. 第三放平台部署deepseek

有时候我们会发现使用deepseek服务器&#xff0c;异常卡顿&#xff0c;这是由于多方面原因造成的&#xff0c;比如说访问人数过多等。想要解决这个问题&#xff0c;我们可以选择第三方平台进行部署 第三方平台 我们可以选择的第三方平台很多&#xff0c;比如硅基流动、秘塔搜索…

1.4-蜜罐\堡垒机\API接口

1.4-蜜罐\堡垒机\API接口 蜜罐&#xff1a;用来钓鱼或诱惑测试人员的防护系统 bash <(curl -sS -L https://hfish.net/webinstall.sh) # 安装HFISH蜜罐堡垒机&#xff1a; 运维用的&#xff0c;统一管理运维平台;拿下堡垒机就很有可能等于拿下了多个平台 jumpServer一键安…

知识图引导的检索增强生成

摘要 检索增强生成&#xff08;RAG&#xff09;已经成为一种很有前途的技术&#xff0c;用于解决大型语言模型&#xff08;LLM&#xff09;生成的响应中的幻觉问题。现有的RAG研究主要集中在应用基于语义的方法来提取孤立的相关组块&#xff0c;忽略了它们之间的内在关系。在本…

【机器学习】imagenet2012 数据预处理数据预处理

【机器学习】数据预处理 1. 下载/解压数据2. 数据预处理3. 加载以及训练代码3.1 使用PIL等加载代码3.2 使用OpenCV的方式来一张张加载代码3.3 h5的方式来加载大文件 最后总结 这个数据大约 140个G,128w的训练集 1. 下载/解压数据 首先需要下载数据&#xff1a; 数据最后处理…

质量工程:数字化转型时代的质量体系重构

前言&#xff1a;质量理念的范式转移阅读原文 如果把软件开发比作建造摩天大楼&#xff1a; 传统测试 竣工后检查裂缝&#xff08;高成本返工&#xff09; 质量工程 从地基开始的全流程监理体系&#xff08;设计图纸→施工工艺→建材选择→竣工验收&#xff09; IEEE研究…

【全栈开发】—— Paddle OCR 文字识别 + deepseek接入(基于python 最新!!!)

所有源码都在文章中&#xff0c;大家不要私信来要源码&#xff0c;当然&#xff0c;评论区欢迎交流技术 目录 Paddle OCR 配置环境 示例 deepseek接入 环境配置 api 调用代码 sliconflow Paddle OCR 配置环境 清华源下载 paddlepaddle&#xff1a; pip install paddlepaddle …