深入探索JDBC:Java数据库连接技术详解与实战应用

news2025/1/12 6:51:21

在这里插入图片描述

Java Database Connectivity(JDBC)是Java语言中用于访问关系型数据库的标准接口。它定义了一组API,使得Java程序能够以统一的方式连接、访问和操作不同的关系型数据库。JDBC不仅简化了数据库操作,还提高了Java应用程序的可移植性和可维护性。

1. 下载并导入MySQL驱动jar包

一键直达:https://mvnrepository.com/

下载方法:

简单粗暴版导入方式:

2. 使用JDBC的基本步骤

在Java中使用JDBC与数据库交互,通常包括以下步骤:

  1. 创建数据源对象,描述了数据从哪里来,数据库服务器的位置
  2. 和数据库服务器建立网络连接
  3. 使用PreparedStatement构造SQL语句
  4. 把SQL发送到服务器上执行
  5. 释放资源

2.1. 创建数据源对象

首先需要创还能数据源对象,描述了数据从哪里来,数据库服务器的位置

url说明:

2.2. 建立连接

把上面的信息都补充完毕之后就可以和数据库服务器建立网络连接了

Connection connection = mysqlDataSource.getConnection();

如果说上面创建数据源对象或是设置信息时有误,这里的连接就会抛出异常

同时要注意选择的是java.sql下的Connection接口

2.3. 创建SQL语句

String sql = "insert into student values('赵六',80)";
PreparedStatement statement = connection.prepareStatement(sql);

这里创建sql语句时不需要加 ‘;’,在控制台中添加分号是因为控制台需要知道当前输入的enter是换行还是执行当前sql,如果说字符串中包含多条sql是需要加的

2.4. 执行SQL

int l = statement.executeUpdate();
System.out.println(l);

这里的方法返回值代表有几行数据受到了影响

2.5. 释放资源

statement.close();
connection.close();

释放资源还是采用先开后关的原则

public class TestJDBC1 {
    public static void main(String[] args) throws SQLException {
        //创建数据源对象,描述了数据从哪里来,数据库服务器的位置
        MysqlDataSource mysqlDataSource = new MysqlDataSource();
        mysqlDataSource.setUrl("jdbc:mysql://127.0.0.1:3306/test2?characterEncoding=utf8&useSSL=false");
        mysqlDataSource.setUser("root");
        mysqlDataSource.setPassword("1234");
        //和数据库服务器建立网络连接
        Connection connection = mysqlDataSource.getConnection();
        System.out.println(connection);
        //使用PreparedStatement构造SQL语句
        String sql = "insert into student values('赵六',80)";
        PreparedStatement statement = connection.prepareStatement(sql);
        //把SQL发送到服务器上执行
        int l = statement.executeUpdate();
        System.out.println(l);
        //释放资源
        statement.close();
        connection.close();
    }
}

3. 使用Set系列方法设置值

在上面的演示中,我们是把一条SQL语句写死了,不够灵活,可以添加键盘录入的方式

但是这样的方式也有弊端,首先就是编写容易出错,其次就是可能会引起“sql注入攻击”,推荐使用下面的方式:

public class TestJDBC2 {
    public static void main(String[] args) throws SQLException {
        Scanner sc = new Scanner(System.in);
        String name = sc.nextLine();
        int grade = sc.nextInt();
        //这里采用另一种方式来创建数据源对象
        DataSource dataSource = new MysqlDataSource();
        ((MysqlDataSource) dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/test2?characterEncoding=utf8&useSSL=false");
        ((MysqlDataSource) dataSource).setUser("root");
        ((MysqlDataSource) dataSource).setPassword("ljl0909");
        //和数据库服务器建立网络连接
        Connection connection = dataSource.getConnection();
        System.out.println(connection);
        //使用PreparedStatement构造SQL语句
        String sql = "insert into student values(?,?)";
        PreparedStatement statement = connection.prepareStatement(sql);
        statement.setString(1, name);
        statement.setInt(2, grade);
        //把SQL发送到服务器上执行
        int l = statement.executeUpdate();
        System.out.println(l);
        //释放资源
        statement.close();
        connection.close();
    }
}

可以根据具体类型选取不同的方法

4. 使用get系列方法获取值

update / delete操作和insert into 方法类似,都是使用executeUpdate(),查询操作使用的是executeQuery()方法,返回值肯定就不是影响的行数了,而是把查询到的数据存放在结果集合中,通过遍历结果集合,就可以达到查询的效果

public class TestJDBC3 {
    public static void main(String[] args) throws SQLException {
        //创建数据源对象
        MysqlDataSource mysqlDataSource = new MysqlDataSource();
        mysqlDataSource.setUrl("jdbc:mysql://127.0.0.1:3306/test2?characterEncoding=utf8&useSSL=false");
        mysqlDataSource.setUser("root");
        mysqlDataSource.setPassword("ljl0909");
        //和数据库建立网络连接
        Connection connection = mysqlDataSource.getConnection();
        //使用PreparedStatement构造SQL语句
        String sql = "select * from student";
        PreparedStatement statement = connection.prepareStatement(sql);
        //执行SQL,查询结果存储在结果集中
        ResultSet resultSet = statement.executeQuery();
        //遍历结果集
        while (resultSet.next()) {
            System.out.println(resultSet.getString("name"));
            System.out.println(resultSet.getInt("grade"));
        }
        //关闭资源
        resultSet.close();
        statement.close();
        connection.close();
    }
}

遍历的方式有些类似集合中使用迭代器遍历的方式

在使用get方法获取值时要根据具体类型选择相应的get方法,并且传入的参数要和目标列的列名对应

在关闭资源时,比更新操作还多了一个ResultSet对象需要关闭

总结

本篇文章详细介绍了JDBC编程的步骤及配置,并演示了插入和查询的操作,如何通过set和get系列方法灵活设置和获取数据,后续还会继续完善补充

在这里插入图片描述

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

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

相关文章

抢先看:2024云栖大会体验攻略

这是一场「AI」奇妙之旅。 2024云栖大会定档 9月19日! 期待与你在 杭州云栖小镇 共度一场为期3天的科技盛会 三日主论坛 400分论坛 与并行话题 4万平米 智能科技展区 免费领取云栖大会门票 怎么看、怎么玩、怎么逛 超长干货攻略奉上,请查收 ⬇️…

将OpenHarmony RK设备散包镜像打包为一个整包

本篇文章教大家使用瑞芯微的Linux_Pack_Firmware工具将rk设备的多个镜像文件打包为一个固件。首先感谢大佬AlgoIdeas开源的打包工具,开源地址:https://gitee.com/openharmony-driver/ril_adapter 接下来进行演示,下面我们使用OpenHarmony 4.…

js运算符----三元运算符

&#xff1f;前为真就执行&#xff1f;号后面的&#xff0c;为假就执行&#xff1a;号后边的 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge…

828华为云征文|Flexus云服务器X实例赋能,用Python将微信公众号秒变智能聊天机器人

&#x1f3c6;作者简介&#xff0c;黑夜开发者&#xff0c;CSDN领军人物&#xff0c;全栈领域优质创作者✌&#xff0c;CSDN博客专家&#xff0c;阿里云社区专家博主&#xff0c;2023年6月CSDN上海赛道top4。 &#x1f3c6;数年电商行业从业经验&#xff0c;AWS/阿里云资深使用…

微服务——服务注册和发现(一)

服务注册和发现 1.1.服务注册背景 假如某项微服务被调用较多&#xff0c;为了应对更高的并发&#xff0c;我们进行了多实例部署&#xff0c;如图&#xff1a; 此时&#xff0c;每个item-service的实例其IP或端口不同&#xff0c;问题来了&#xff1a; item-service这么多实例…

【JUC】12-CAS

1. CAS compare and swap&#xff0c;比较并交换。 包含三个操作数&#xff1a;内存位置、预期原值及更新值。 执行CAS操作的时候&#xff0c;将内存位置的值与预期原值比较&#xff1a; 匹配&#xff0c;更新为新值。不匹配&#xff0c;不进行操作&#xff0c;多个线程同时…

SpringCloud开发实战(五):Feign的一些优化建议

目录 SpringCloud开发实战&#xff08;一&#xff09;&#xff1a;搭建SpringCloud框架 SpringCloud开发实战&#xff08;二&#xff09;&#xff1a;通过RestTemplate实现远程调用 SpringCloud开发实战&#xff08;三&#xff09;&#xff1a;集成Eureka注册中心 SpringCloud开…

nefu暑假集训5 KMP 个人模板+例题汇总

前言&#xff1a; KMP算法用于匹配字符串&#xff0c;假设长字符串为s&#xff0c;需要匹配的字符串是p。KMP算法的基础思想是利用一个next[n]数组&#xff1a;next[i]对应的是&#xff1a;以下标i为结尾的连续子串&#xff0c;与以第一个字符开始的子串&#xff0c;相等的最大…

UE 【材质编辑】自定义ShadingMode

【UE 4.27.2】 在UE中提供了多种多样的ShadingMode&#xff0c;相当于一种风格化的处理方案(整体全面的流程调整)&#xff0c;切换ShadingMode可以看到不同的显示效果&#xff1a; 通过简单的拓展&#xff0c;我们可以实现自定义的ShadingMode&#xff0c;使得我们切换到自己的…

JMeter:如何定制Http请求取样器

一般使用JMeter发送HTTP请求时都会用到HTTP Request取样器&#xff0c;这种取样器大多数时候能够满足压力测试的需要。 图1 但也有一些场景&#xff0c;可能需要更加强大的取样器&#xff0c;或者需要定制一些功能&#xff0c;这时就需要自己手动编写取样器。幸好JMeter为我们提…

leveldb源码剖析(二)——LSM Tree

LSM Tree LSM Tree&#xff1a;Log-Structured Merge Tree&#xff0c;日志结构合并树。是一种频繁写性能很高的数据结构。 LSM Tree将写入操作与合并操作分离&#xff0c;数据首先写入磁盘中的日志文件&#xff08;WAL&#xff09;&#xff0c;随后写入内存缓存&#xff0c;…

Android经典实战之Textview文字设置不同颜色、下划线、加粗、超链接等效果

本文首发于公众号“AntDream”&#xff0c;欢迎微信搜索“AntDream”或扫描文章底部二维码关注&#xff0c;和我一起每天进步一点点 SpannableString 在 Android 开发中是一个非常强大的工具&#xff0c;它允许你在单个字符串范围内应用多种样式。使用 SpannableString&#xf…

【 C++ 】 类和对象的学习 (二)

&#x1f618;我的主页&#xff1a;OMGmyhair-CSDN博客 目录 I、类的默认成员函数 一、构造函数 二、析构函数 三、拷贝构造函数 四、 运算符重载 赋值运算符重载 五、取地址重载_普通对象 六、取地址重载_const对象 I、类的默认成员函数 用户没有显示实现&#xff0…

Linux学习笔记5 值得一读,Linux(ubuntu)软件管理,搜索下载安装卸载全部搞定!(上)

本文记录Ubuntu操作系统的软件包管理。 一、背景 整个Linux系统就是大大小小的软件包构成的&#xff0c;在linux系统中&#xff0c;软件的管理非常重要&#xff0c;与其他操作系统不同&#xff0c;linux的软件包管理比较复杂&#xff0c;有时还需要处理软件包之间的冲突。本文…

Python | 泰勒图

写在前面 最近&#xff0c;开始对于CMIP6的一些数据进行评估。Talor图是一个很好展现模式间误差的方式&#xff0c;这里简单记录一下在python中的实现方式。 主要为半图的画法 参考的代码为&#xff1a; https://zenodo.org/records/5548061 效果大致下面这个样子 这边在原…

maven中如何配置多个仓库使其同时生效

场景 有一个项目&#xff0c;我把代码跟本地maven依赖包从同事那里拷贝过来&#xff0c;然后打包却一直打不了&#xff0c;一直报aliyun仓库找不到这个依赖的错误&#xff0c;无论我改成引用本地仓库还是线上aliyun仓库都不行。 依赖 <dependency><groupId>org.spr…

有三层交换机就不用路由器了?真的假的

号主&#xff1a;老杨丨11年资深网络工程师&#xff0c;更多网工提升干货&#xff0c;请关注公众号&#xff1a;网络工程师俱乐部 晚上好&#xff0c;我的网工朋友。 在现代企业网络环境中&#xff0c;三层交换机因其高效的数据包处理能力和较低的延迟而受到广泛欢迎。 然而&…

Python 从入门到实战7(元组)

我们的目标是&#xff1a;通过这一套资料学习下来&#xff0c;通过熟练掌握python基础&#xff0c;然后结合经典实例、实践相结合&#xff0c;使我们完全掌握python&#xff0c;并做到独立完成项目开发的能力。 之前的文章我们通过举例学习了python 中列表的定义及相关操作。今…

Echarts大屏可视化

构建可视化大屏&#xff1a; 构建布局&#xff1a;通过css和html对整个页面进行模块拆分&#xff0c;控制好每一张图的位置和大小&#xff0c;再将echarts实例化对象放到不同的盒子里 效果图&#xff1a; 代码&#xff1a; <!DOCTYPE html> <html lang"en&quo…

斯普林格-《土木工程与结构抗震设计》 Springer-Civil Engineering and Structural Seismic Design

文章目录 一、会议详情二、重要信息三、大会介绍四、出席嘉宾五、征稿主题六、咨询 一、会议详情 二、重要信息 大会官网&#xff1a;https://ais.cn/u/vEbMBz提交检索&#xff1a;EI Compendex、IEEE Xplore、Scopus最终截稿&#xff1a;2024年9月2日23:59 三、大会介绍 四…