JDBC编程方法及细节

JDBC(Java Database Connectivity)是Java编程语言用于连接和操作数据库的API(Application Programming Interface)。它为开发人员提供了一组Java类和接口,用于与各种关系型数据库进行通信。使用JDBC,开发人员可以轻松地执行数据库操作,如查询、插入、更新和删除数据。

JDBC提供了一种标准的方式来连接数据库,并通过执行SQL语句与数据库进行交互。它允许开发人员使用Java代码来创建数据库连接、发送SQL语句并处理结果。通过JDBC,开发人员可以跨不同的数据库系统,如MySQL、Oracle、SQL Server等,使用相同的编程接口进行数据库操作。

1. 引入JDBC驱动包

要想使用JDBC编程要先引入MySQL的JDBC驱动包,JDBC驱动包就是Java对于数据库原生接口的封装,这种驱动包属于第三方库并不包含在JDK中 ,所有需要把它下载下来并且引入项目中。

1.1 下载方法

打开网站:https://mvnrepository.com/

点击上方的搜索框,输入 mysql 然后点击 Search 

然后点击如下图第二个搜索结果

然后来到如下界面,向下找到对应自己的MySQL版本,然后点击版本号进去

然后点击如图所示的jar即可下载

1.2 引入项目

1. 先创建一个项目

2. 右键图中的.idea然后点检 新建 / 目录

命名可任意,一般命名为lib

3. 将下载好的jdbc驱动包复制然后粘贴到新建的目录中

 3. 右击目录 点击添加到库 然后点击确定即可

2. JDBC编程步骤

2.1 创建数据源

数据库是服务器,服务器可能可能在这台主机上,也可能在其他主机上,我们要明确这个服务器的位置才能对其进行操作

数据源就是描述你要操作的数据库在哪里

这里Java是通过  IP地址 + 端口号 + 数据库名 来定位数据库位置的 

 解释:

  • IP地址: IP地址是描述一台主机在网络上的位置的机制,通常由一串数字组成 
  • 端口号:一台主机上有很多服务程序,使用端口号区分不同的服务程序 

 注意:

127.0.0.1 是一个特殊的IP地址,叫做环回IP(loopback)表示本机

MySQL默认的端口号为3306

代码:

//1.创建数据源
DataSource dataSource = new MysqlDataSource();
//解释,DataSource 是Java JDBC 中原生的API接口,MysqlDataSource 是我们安装的驱动包中的内容
((MysqlDataSource)dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/java1124?characterEncoding=utf8&uesSSL=false");
((MysqlDataSource)dataSource).setUser("root");
((MysqlDataSource)dataSource).setPassword("123456");

解释: 

1. ((MysqlDataSource)dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/java1124?characterEncoding=utf8&uesSSL=false");

  1. jdbc:mysql://:表示使用JDBC连接到MySQL数据库。
  2. 127.0.0.1:表示数据库服务器的IP地址,这里为本地主机。
  3. 3306:表示MySQL数据库服务器的端口号,一般情况下默认为3306。
  4. java1124:表示要连接的具体数据库名称。
  5. ?characterEncoding=utf8&uesSSL=false:表示额外的连接参数。characterEncoding=utf8:指定字符编码为UTF-8,确保正确处理中文等特殊字符。useSSL=false:禁用SSL连接

2. ((MysqlDataSource)dataSource).setUser("root");

这行代码设置了数据库连接的用户名。同样是将dataSource转换为MysqlDataSource类型,然后调用setUser()方法,将数据库连接的用户名设置为root,这是一个常见的MySQL数据库的默认用户名,拥有所有权限

3. ((MysqlDataSource)dataSource).setPassword("123456");

这行代码设置了数据库连接的密码。同样是将dataSource转换为MysqlDataSource类型,然后调用setPassword()方法,将数据库连接的密码设置为123456,这是与用户名对应的数据库连接密码,即我们安装MySQL时自己设置的密码

2.2 和数据库服务器建立连接 

//2.和数据库服务器建立连接 
Connection connection = dataSource.getConnection();
//注意这里的Connection要使用java.sql包下的Connection
//使用getConnection()方法会抛出一个SQLException异常记得捕获或者抛出这个异常

2.3 构建一个SQL语句

1. 创建一个字符串类型的SQL语句

 //注意末尾不需要加“;” 
String sql = "insert into student values(1, 'Ting')";

2 .将String类型的SQL语句转化为语句对象

//将String类型的SQL语句转化为语句对象
PreparedStatement statement = connection.prepareStatement(sql);

注意:还有一个 Statement接口也可以完成该操作,但是他们有一些区别如下:

  1. 创建方式:

    • Statement: 通过Connection对象的createStatement()方法创建。
    • preparedStatement:通过Connection对象的preparedStatement()方法创建,需要传入SQL语句作为参数。
  2. 预编译:

    • Statement:不进行预编译,每次执行SQL语句时都会将SQL语句发送给数据库进行解析和编译。
    • preparedStatement:在创建时进行了预编译,即SQL语句被发送到数据库进行解析和编译,并生成可复用的执行计划。这样,在后续的执行过程中,只需要传递参数即可,无需重新解析和编译SQL语句,提高了执行效率。
  3. 参数设置:

    • Statement:执行SQL语句时,无法使用参数化查询,所有的参数值都必须通过字符串拼接的方式直接嵌入SQL语句中。
    • preparedStatement:支持参数化查询,可以使用占位符(如?)代替具体的参数值,然后通过调用setXXX()方法设置参数的值。
  4. 防止SQL注入:

    • Statement:由于无法参数化查询,容易受到SQL注入攻击。因为参数值直接嵌入到SQL语句中,如果参数值未经过正确的处理,可能会导致安全漏洞。
    • preparedStatement:使用参数化查询,可以有效预防SQL注入攻击。参数值在设置时会被正确处理,不会直接嵌入到SQL语句中,从而提高了安全性。

 2.4 把构造好的SQL语句发送给服务器执行

增删改操作使用 :executeUpdate() 方法 返回值为int类型 即为影响的行数。

查询操作使用:executeQuery() 方法 返回值为 ResultSet 为一个结果集 

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

 2.5 释放资源

Connection connection 和 PreparedStatement statement 是需要释放资源的,

因为它们占据了一些计算机重要的软/硬件资源

 DataSource dataSource 不需要释放,因为它只储存了 一些信息

使用close() 方法释放资源 

//注意释放顺序要与创建顺序相反
statement.close();
connection.close();

 2.6 问题

在 2.3 中我们发现我们的SQL语句是写死的 如果要插入其他内容又需要重新修改代码,显然这样是不科学的

解决方案:

1. 字符串拼接

在构造SQL语句时我们使用字符串拼接的方式来构造

String sql = "insert into student values(" + id + ", '" + name + "')";

这样就把插入的内容改为可由用户输入了,避免了修改代码

但是这样写任然存在一些问题

1.出的代码太过冗余杂乱

2.有sql注入攻击的风险

例如:用户在输入时 输入 "  ');drop database;"

 

2. 使用 preparedStatement 提供的占位符

String sql = "insert into student values(?, ?)";
//将String类型的SQL语句转化为语句对象
PreparedStatement statement = connection.prepareStatement(sql);
statement.setInt(1, id);//把第一个 ? 设置为 id
statement.setString(2, name);//把第二个 ? 设置为 name

 2.7 查询

构造查询语句与增删改略有不同,注意查询结果的打印方式即可

    public static void main(String[] args) throws SQLException {//构造数据源DataSource datasource = new MysqlDataSource();((MysqlDataSource)datasource).setUrl("jdbc:mysql://127.0.0.1:3306/java1124?characterEncoding=utf8&useSSL=false");((MysqlDataSource)datasource).setUser("root");((MysqlDataSource)datasource).setPassword("123456");//连接数据库Connection connection = datasource.getConnection();//构造SQL语句String sql = "Select * from student";PreparedStatement statement = connection.prepareStatement(sql);//发送到服务器执行ResultSet result = statement.executeQuery();while(result.next()){int id = result.getInt("id");String name = result.getString("name");System.out.println(id + " " + name);}//释放资源result.close();statement.close();connection.close();}

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

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

相关文章

PHPStudy开发环境解决:启动报错 class websocket/server not found

如果您使用的是PHPStudy作为您的PHP开发环境,您可以按照以下步骤来安装Ratchet库并启动WebSocket服务器: 1. 打开PHPStudy的安装目录,在命令行中进入该目录。 2. 在命令行中运行以下命令来安装Ratchet库: composer require cboden…

FL Studio21.2.0中文语言包编曲软件入门讲解

FL Studio常称水果,是一款功能强大的编曲软件,集编曲,录音,剪辑,混音于一身,简单易上手,灵活性高,强大到突破想象。 FL Studio,当前版本 FL Studio21,百分之…

C语言第二十九弹---求n的阶乘

C语言求n的阶乘 递归法 思路&#xff1a;因为n的阶乘是 nn-1…321,所以设定初始条件为1 &#xff0c;递归使用n*函数&#xff08;n-1&#xff09;这样就可以不断接近初始条件。 代码如下 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h>int FindFact(int n) {if…

linux如何获取CPU使用率

Linux 中 一切皆为文件 的设计理念带来了许多好处: 统一接口: 使用相同的 API 可以对所有类型的文件进行操作&#xff0c;例如读取、写入、移动、删除、修改权限等 简化管理: 使用相同的工具和方式来管理文件和设备的操作&#xff0c;例如备份、复制、移动、删除、链接等 编程…

统计二叉树中的伪回文路径 : 用位运用来加速??

题目描述 这是 LeetCode 上的 「1457. 二叉树中的伪回文路径」 &#xff0c;难度为 「中等」。 Tag : 「DFS」、「位运算」 给你一棵二叉树&#xff0c;每个节点的值为 1 到 9 。 我们称二叉树中的一条路径是 「伪回文」的&#xff0c;当它满足&#xff1a;路径经过的所有节点值…

使用Python的turtle模块绘制彩色螺旋线

1.1引言&#xff1a; 在Python中&#xff0c;turtle模块是一个非常有趣且强大的工具&#xff0c;它允许我们以一个可视化和互动的方式学习编程。在本博客中&#xff0c;我们将使用turtle模块来绘制一个彩色的螺旋线。通过调用各种命令&#xff0c;我们可以引导turtle绘制出指定…

vue使用xlsx导入到表格中代码

以下是使用xlsx导入表格的代码示例&#xff1a; 安装依赖包 npm install xlsx -S引入xlsx和vue-xlsx import * as XLSX from "xlsx"; import VueXlsx from "vue-xlsx";在Vue组件中使用VueXlsx <template><div><input type"file&qu…

Vue项目实战之一----实现分类弹框效果

效果图 实现 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title><script src"js/vue.js"></script><!-- 引入样式 --><link rel"stylesheet&qu…

前端项目打包放到springboot项目时,访问不带index.html

当您的前端项目被打包并放到 Spring Boot 项目中时&#xff0c;如果想要通过访问不带 index.html 的路径来直接进入前端页面&#xff0c;您可以使用以下方法&#xff1a; 1&#xff0c;在 Spring Boot 项目中添加一个路由规则&#xff0c;将所有对特定路径的请求重定向到前端页…

leetcode:随机链表的复制

题目描述 题目链接&#xff1a;138. 随机链表的复制 - 力扣&#xff08;LeetCode&#xff09; 题目分析 这个题目很长&#xff0c;但是意思其实很简单&#xff1a;就是一个单链表&#xff0c;每个结点多了一个指针random随机指向链表中的任意结点或者NULL&#xff0c;我们血需…

Linux后台运行Python的py文件,如何使ssh工具退出后仍能运行

常规运行 python3 mysqlbak.py ssh工具退出后&#xff0c;或ctrlc中断后&#xff0c;程序将不在运行 后台运行 nohup python3 mysqlbak.py > mysqlbak.log & > mysqlbak.log为可选项&#xff0c;输出日志到指定文件&#xff0c;如果不写&#xff0c;输出日志到nohup…

android studio如何给安卓虚拟机发送短信

首先&#xff0c;cd到指定路径 默认情况下&#xff0c;Android SDK通常安装在以下位置&#xff1a; Windows&#xff1a;C:\Users\YourUsername\AppData\Local\Android\Sdk\platform-toolsmacOS&#xff1a;/Users/YourUsername/Library/Android/sdk/platform-toolsLinux&…

【Mysql学习笔记】3 - 本章作业

1.判断 1. 这句话表示ename as name 可以不要这个as&#xff0c;同理后面的sal salary也是别名&#xff0c;而选项D的Annual Salary中间也有空格&#xff0c;程序会判断为as 但as不能连用&#xff0c;所以错误&#xff0c;选D 2.选B&#xff0c;因为null不能加上判断符号<&…

oracle rac环境归档日志清除

文章目录 一、处理步骤1、使用终端登录上服务器查看磁盘使用状态2、使用恢复备份管理工具RMAN删除归档日志 二、详细操作步骤三、定时任务自动清归档日志1、编写删除脚本4、测试脚本运行情况5、设置定时任务每周执行一次&#xff0c;并测试运行效果 昨天单位的所有系统都连不上…

JoyT的科研之旅第一周——科研工具学习及论文阅读收获

CiteSpace概述 CiteSpace 是一个用于可视化和分析科学文献的工具&#xff0c;它专门针对研究者进行文献回顾和趋势分析。CiteSpace 的核心功能是创建文献引用网络&#xff0c;这些网络揭示了研究领域内各个文献之间的相互关系。使用 CiteSpace 可以为论文研究做出贡献的几种方…

激光塑料透光率检测仪进行材料质量监控

焊接质量检测是对焊接成果的检测&#xff0c;目的是保证焊接结构的完整性、可靠性、安全性和使用性。焊接质量检测通常包括外观检验、内部检查、无损检测以及试件制作与送检等步骤。通过这些检测方法&#xff0c;可以全面评估焊接质量&#xff0c;确保其符合设计要求和规范标准…

jenkins + gitlab 自动部署(webhook)

Jenkins是一个流行的开源CI/CD工具&#xff0c;可以与Git等版本控制系统集成&#xff0c;实现自动构建、测试和部署。Webhook是一种机制&#xff0c;可以在Git仓库中设置&#xff0c;在代码提交或合并请求时触发Jenkins构建任务&#xff0c;以完成自动化部署。 实操 设备信息 …

精准人脉引流软件的开发流程与涉及到的技术

一、精准人脉引流软件的开发流程 1. 确定需求&#xff1a;首先&#xff0c;我们需要明确软件的需求&#xff0c;包括目标用户、功能需求、性能需求等。这些需求将直接影响到软件的开发方向和最终效果。 2. 系统设计&#xff1a;根据需求&#xff0c;进行系统设计&#xff0c;…

Linux常用命令——bind命令

在线Linux命令查询工具 bind 显示或设置键盘按键与其相关的功能 补充说明 bind命令用于显示和设置命令行的键盘序列绑定功能。通过这一命令&#xff0c;可以提高命令行中操作效率。您可以利用bind命令了解有哪些按键组合与其功能&#xff0c;也可以自行指定要用哪些按键组合…

【Unity3D】MAX聚合广告SDK——Pangle广告接入

Pangle, App Monetization Simplified 注册 登录 创建应用 创建广告单元 将其应用ID和广告ID关联到MAX广告。 下载Pangle Unity Plugin包&#xff0c;新建一个空工程&#xff08;很重要&#xff09; Unity版本2019.4.0f1 gradle plugin 4.2.0 gradle版本6.7.1 build_tools 34.…