JDBC编程复习

news2024/11/28 18:36:03

文章目录

  • JDBC
    • 1.概念
    • 2.原理
    • 3. 如何使用JDBC编程
      • 1. 下载mysql的jdbc驱动
      • 2. 项目中引入驱动
    • 4. JDBC使用
      • 1. 和数据库建立连接
      • 2.获取连接
      • 3. Statement对象
      • 4. 释放资源


JDBC

1.概念

JDBC,即Java Database Connectivity,java数据库连接。是Java提供的API用来执行SQL语句,它是Java中的数据库连接规范,这个API由java.sql.*,javax.sql.*包中的一些类和接口构成,它为Java开发人员操作数据库提供了一个标准的API,提供了多种关系的数据空提供访问。

2.原理

JDBC为多种关系数据库提供了统一访问方式,数据库的种类有很多,每个数据库提供的接口都各不同,Java就能够使用一套代码就能操作各种不同种类的数据库。

Java开发者只需呀关注怎么使用就可以了,JDBC的API是Java标准库里提供好的类,驱动程序往往是一个jar包,访问的是数据库服务器。

在这里插入图片描述

3. 如何使用JDBC编程

1. 下载mysql的jdbc驱动

  • MySQL官网下载
  • 从MySQL的githup下载
  • Maven中央仓库下载

在这里插入图片描述

需要注意的是,如果MySQL的服务器是5.7话,那么驱动包也得是5系列的,8就用8系列的驱动包.

下载后的jar包里其实就是包含了很多.class文件,安装特定的目录结构组织,能够被Java识别.

2. 项目中引入驱动

  1. 创建一个目录
  2. 把jar包拷贝进来
  3. 由键这个目录,add as libray
  4. 然后确定即可

在这里插入图片描述

4. JDBC使用

1. 和数据库建立连接

这个URL是和数据库建立连接时必备的它的基本格式为

String URL = "jdbc:mysql://127.0.0.1:3306/system_book?characterEncoding=utf8&useSSL=false";
  • jdbc:mysql:协议名,对于JDBC来说是固定的
  • 127.0.0.1:数据库服务器ip(这里表示本机Ip)
  • 3306:MySQL默认端口号
  • system_book:数据库名
  • characterEncoding=utf8:当前成员以utf8字符集解析数据
  • useSSL=false:传输是否加密

创建连接代码

private static final String URL = "jdbc:mysql://127.0.0.1:3306/system_book?characterEncoding=utf8&useSSL=false";
    private static final String USER = "root";
    private static final String PASSWORD = "root";
    private static DataSource dataSource = new MysqlDataSource();
    static {
        ((MysqlDataSource)dataSource).setURL(URL);
        ((MysqlDataSource)dataSource).setUser(USER);
        ((MysqlDataSource)dataSource).setPassword(PASSWORD);
    }
  • USER:数据库用户名

  • PASSWORD:数据库密码

  • DataSource:是JDBC提供的一个接口

  • MysqlDataSource:是一个类,实现了DataSource接口,用于MySQL操作数据库

  • 这里的setURLsetUsersetPassword都是MysqlDataSource的方法

  • 为啥上述方法不是DataSource接口的?原因就是并不是所有数据都能设置者几个东西

  • 这里的代码为啥要先向上转型再向下转型呢?其实可以写成这样

    MysqlDataSource mysqlDataSource = new MysqlDataSource();
            mysqlDataSource.setURL(URL);
            mysqlDataSource.setUser(USER);
            mysqlDataSource.setPassword(PASSWORD);
    
  • 使用DataSource的好处就是,我们持有的是DataSource示例,它可以接受实现了它的其它类,假设如果后续要更换数据库,只需要修改这几行代码即可。如果使用MysqlDataSource就要修改大量代码

2.获取连接

DataSource dataSource = new MysqlDataSource();
((MysqlDataSource)dataSource).setURL(URL);
        ((MysqlDataSource)dataSource).setUser(USER);
        ((MysqlDataSource)dataSource).setPassword(PASSWORD);
Connection connection = dataSource.getConnection();

在这里插入图片描述

还有一种获取连接的方式,通过DriverManager(驱动管理类)的静态方法获取

Class.forName("com.mysql.jdbc.Driver");
            Connection connection = DriverManager.getConnection(URL);

以上两种方式的区别是:

  • DriverManager类来获取的Connection连接,是无法重复利用的,每次使用完以后释放资源
    时,通过connection.close()都是关闭物理连接
  • DataSource提供连接池的支持。连接池在初始化时将创建一定数量的数据库连接,这些连接
    是可以复用的,每次使用完数据库连接,释放资源调用connection.close()都是将
    Conncetion连接对象回收

3. Statement对象

Statement对象主要是将SQL语句发送到数据库中。JDBC API中主要提供了三种Statement对象

  1. PreparedStatement
    • 用于执行带或不带参数的SQL语句
    • SQL语句会预编译再数据库系统
    • 执行速度快于Statement对象
  2. Statement
    • 用于执行不带参数的简单SQL语句
  3. CallableStatement
    • 用于执行数据库存储过程的调用

当然PreparedStatement是最常用的,主要有executeQuery() 方法和executeUpdate()方法

  • executeQuery() 方法执行后返回单个结果集的,通常用于select语句
  • executeUpdate()方法返回值是一个整数,指示受影响的行数,通常用于update、insert、delete
    语句

带有参数的SQL执行

public boolean add(Book book) {
        Connection connection = null;
        PreparedStatement statement = null;

        try {
            // 和数据库建立连接
            connection = DBUtil.getConnection();
            // 拼装sql
            String sql =  "insert into book values (null,?,?,?,?,?)";
            statement = connection.prepareStatement(sql);
            statement.setString(1,book.getName());
            statement.setString(2,book.getAuthor());
            statement.setString(3,book.getType());
            statement.setBigDecimal(4,book.getPrice());
            statement.setString(5,"未借出");
            // 执行sql
            int ret = statement.executeUpdate();
            if (ret > 0) {
                return true;
            }

        } catch (SQLException throwables) {
            throwables.printStackTrace();
        } finally {
            DBUtil.close(connection,statement,null);
        }

        return false;
    }

不带参数的SQL执行

ResultSet对象:ResultSet是一个结果集 ,它代表符合SQL语句条件的所有行,并且它通过一套getXXX方法提供
了对这些行中数据的访问 ,我们如果想要取得某一条记录,就要使用ResultSet的next()方法 ,如果我们想要得到ResultSet里的所有记录,就应该使用while循环 。

public List<Book> getAll() {
        Connection connection = null;
        PreparedStatement statement = null;
        ResultSet resultSet = null;
        List<Book> bookList = new ArrayList<>();
        try {
            // 和数据库建立连接
            connection = DBUtil.getConnection();
            // 拼装sql
            String sql = "select * from book";
            statement = connection.prepareStatement(sql);
            // 执行sql
            resultSet = statement.executeQuery();
            while (resultSet.next()) {

                String bookName = resultSet.getString("name");
                String auth = resultSet.getString("author");
                String type =  resultSet.getString("type");
                BigDecimal price = resultSet.getBigDecimal("price");
                String status = resultSet.getString("status");
                Book book = new Book(bookName,auth,type,price);
                book.setLoanOut(("未借出".equals(status) ? false : true));
                bookList.add(book);
            }
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        } finally {
            DBUtil.close(connection,statement,resultSet);
        }

        return bookList;
    }

4. 释放资源

建立连接后,使用完毕后一定要记得释放这个连接,如果不一直不释放可能就会造成资源泄露的情况。

注意释放的顺序一定是先创建的后释放。

try {
                // 先创建的额后释放
                if (resultSet != null) {
                    resultSet.close();
                }
                if (statement != null) {
                    statement.close();
                }
                if (connection != null) {
                    connection.close();
                }


            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }

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

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

相关文章

SWPU新生赛WriteUp

一个线上赛&#xff0c;这个NSSCTF最爽的就是没有靶机操作的一分钟冷却&#xff0c;10.11比赛结束&#xff0c;但是我还要看看工控&#xff0c;所以不打这个比赛了&#xff0c;先把wp写了&#xff0c;pwn入门真TM艰难 WEB 前面送分题&#xff0c;中间的也是基础题&#xff0c;…

SQL概述及数据定义

文章目录一、SQL概述1.简介2.特点3.组成4.SQL分类5.书写规范二、数据定义1.模式的定义与删除①定义模式②删除模式2.基本表的定义、删除与修改①定义基本表②数据类型③模式与表④修改基本表⑤删除基本表3.索引的建立与删除①建立索引②删除索引一、SQL概述 1.简介 SQL (Stru…

使用IDA查看汇编代码上下文去辅助排查C++软件异常问题

目录 1、概述 2、汇编指令能最直接反映异常崩溃的原因 2.1、查看异常Code码及对应的异常类型 2.2、查看发生崩溃的那条汇编指令 3、阅读汇编代码上下文需要掌握一定的基础汇编知识 4、Windbg中显示的函数调用堆栈中的C代码行号&#xff0c;和最新的代码对不上了 5、Wind…

openGL学习之GLFW和GLAD的下载和编译

背景:为什么使用GLFW和GLADOPenGL环境 目前主流的桌面平台是GLFW和GLAD之前使用的GLUT和Free GLUT已经基本淘汰了&#xff0c;所以记录一下如何下载GLFW和GLAD并且编译.GLFW下载:An OpenGL library | GLFW复制到你想存放的位置,我这里就存放到C盘Libaray文件夹下了,这里是我存放…

算法训练营 day37 贪心算法 K次取反后最大化的数组和 加油站 分发糖果

算法训练营 day37 贪心算法 K次取反后最大化的数组和 加油站 分发糖果 K次取反后最大化的数组和 1005. K 次取反后最大化的数组和 - 力扣&#xff08;LeetCode&#xff09; 给你一个整数数组 nums 和一个整数 k &#xff0c;按以下方法修改该数组&#xff1a; 选择某个下标…

Eclipse 版本升级记录

前言 Eclipse 不是不能在线升级&#xff0c;至少没有找对方法&#xff0c;下面就让我来一步一步带你学会它、使用它吧! 一、概念 Eclipse主要分为两个概念&#xff0c;一个是在线升级 Eclipse 新版本&#xff0c;另一个是在线升级 Eclipse 插件&#xff0c;这两个是有很大区…

【记录】ChatGPT使用记录

文章目录2023年02月08日数学哲学Java其他2023年02月09日ChatGPT网络根据对话的日期、问题的类型进行整理 2023年02月08日 数学 感想&#xff1a;数学应该没啥问题&#xff0c;感觉只要自然语言没理解错了&#xff0c;剩下就不是事 积分 代数 哲学 哲学问题的回答就属于模棱…

JetpackCompose从入门到实战学习笔记7—Dialog的简单使用

JetpackCompose从入门到实战学习笔记7—Dialog的简单使用 1.Dialog对话框 Dialog的参数如下: Composable fun Dialog(onDismissRequest: (() -> Unit)?, //关闭对话框的回调properties: DialogProperties! DialogProperties(), //自定义对话框的属性content: ( Compose…

智能无障碍轮椅——汇总

文章目录一、设计内容二、控制理论三、材料列表四、控制图五、硬件介绍1、TB6612FNG电机驱动模块2、DX-BT04 2.0蓝牙模块3、MPU6050陀螺仪模块4、电源模块5、520编码器直流减速电机六、PID理论与算法控制七、代码解析八、参考博文一、设计内容 使用 STM32 作为主处理器进行开发…

Web3.0:互联网新阶段

Web3.0 定义&#xff1a;从后端生产关系革新开始。 Web3.0 是结合了去中心化和代币&#xff08;Token&#xff09;经济学等概念&#xff0c;基于区块链技术的全新的互联网迭代方向&#xff0c;意在解决 Web2.0 带来的生态不平衡、发展不透明等问题。与 AR/VR 等前端创新相比&am…

oracle外键约束、级联删除

根据约束名称查询&#xff1a;select * from user_constraints t where t.CONSTRAINT_NAME 约束名称举例&#xff1a;字段解析&#xff1a;1、CONSTRAINT_NAME&#xff1a;约束名称。2、CONSTRAINT_TYPE&#xff1a;约束类型。3、TABLE_NAME&#xff1a;约束所在的表。4、R_CO…

FreeModbus RTU 移植指南

FreeModbus 简介 FreeModbus 是一个免费的软件协议栈&#xff0c;实现了 Modbus 从机功能&#xff1a; 纯 C 语言支持 Modbus RTU/ASCII支持 Modbus TCP 本文介绍 Modbus RTU 移植。 移植环境&#xff1a; 裸机Keil MDK 编译器Cortex-M3 内核芯片&#xff08;LPC1778/88&…

Intel x86_64 PMU简介

文章目录前言一、性能监控概述二、CPUID information三、架构性能监控3.1 架构性能监控 Version 13.1.1 架构性能监控 Version 1 Facilities3.1.2 预定义的体系结构性能事件3.1.3 cmask demo测试参考资料前言 Intel 64 和 IA-32 架构提供了 PMU&#xff08;Performance Monito…

Oracle Data Guard Apply服务

1. Apply服务介绍 Apply服务自动应用redo到备数据库来保持与主数据库的同步和允许事务一致性访问数据。 缺省情况下&#xff0c;Apply服务等待备redo日志文件进行归档&#xff0c;然后再应用归档日志文件包含的redo。然而&#xff0c;可以启用实时Apply&#xff0c;允许当前的…

CentOS8基础篇2:文件系统

一、文件系统概述 1.文件系统的基本概念 操作系统中负责管理和存储文件信息的软件机构称为文件管理系统&#xff0c;简称文件系统。它规定了文件的存储方式及文件索引方式等信息。文件系统主要由三部分组成&#xff0c;分别是与文件管理相关的软件、被管理的文件和实施文件管…

ip-guard如何查看客户端连接的服务器IP地址?

在客户端上通过“运行”输入win.ini打开文件(在目录C:\\Windows\\),可以从里面找到一个字段SIP,比如SIP=3232237616 再将其换算成16进制数为c0a80830

每天10个前端小知识 【Day 8】

前端面试基础知识题 1. Javascript中如何实现函数缓存&#xff1f;函数缓存有哪些应用场景&#xff1f; 函数缓存&#xff0c;就是将函数运算过的结果进行缓存。本质上就是用空间&#xff08;缓存存储&#xff09;换时间&#xff08;计算过程&#xff09;&#xff0c; 常用于…

在CANoe/CANalyzer中给CAN Log.asc/blf文件“瘦身”

案例背景&#xff08;共7页精讲&#xff09;&#xff1a; 该篇博文将告诉您&#xff0c;如何给离线文件CAN Log.asc/blf文件“瘦身”&#xff1a;批量删除/过滤 CAN Log中&#xff0c;不需要的CAN ID和CAN channel。 目录 1 准备工作 2 插入CAN Filter 3 保存“瘦身” 后的…

一种RK3399+MIPI+FPGA的高速工业相机的设计方案(一)

目 前 &#xff0c; 嵌 入 式 相 机 逐 渐 代 替 了 传 统 相 机 进 入 大 众 的 视 野 &#xff0c; 应 用 在 公 安 刑 侦 、 生 物 医 学和 文 物 保 护 等 诸 多 领 域 。 但 是 随 着 人 们 对 图 像 视 觉 成 像 质 量 追 求 的 提 升 &#xff0c; 图 像 传 感 器 的 特…

ESP32S3系列--SPI主机驱动详解(一)

一、目的SPI是一种串行同步接口&#xff0c;可用于与外围设备进行通信。ESP32S3自带4个SPI控制器外设&#xff08;Master&#xff09;&#xff0c;其中SPI0/SPI1内部专用,共用一组信号线,通过一个仲裁器访问外部Flash和PSRAM&#xff1b;SPI2/3各自使用一组信号线&#xff1b;开…