【Java 进阶篇】JDBC插入数据详解

在这里插入图片描述

在Java应用程序中,与数据库交互是一项常见的任务。其中,插入数据操作是一种基本的数据库操作之一。本文将详细介绍如何使用Java JDBC(Java Database Connectivity)来执行插入数据操作。无论您是初学者还是有一定经验的开发人员,都能从本文中获得有关插入数据的重要信息。

什么是插入数据?

在数据库术语中,插入数据是指将新的数据行添加到数据库表中的操作。这可以是将完全新的数据插入到表中,也可以是更新表中已有的数据。

使用JDBC插入数据的基本步骤

在开始之前,确保您已经设置了Java开发环境,并且已经安装了适当的数据库。我们将以MySQL数据库为例进行说明,但类似的步骤也适用于其他数据库系统。

步骤1:导入JDBC库

首先,您需要导入JDBC库,以便在Java程序中使用数据库功能。通常,您会下载并使用数据库供应商提供的JDBC驱动程序。以下是一些常见的JDBC库导入语句示例:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

步骤2:建立数据库连接

在插入数据之前,您需要建立与数据库的连接。通常,您需要提供数据库的URL、用户名和密码。以下是建立MySQL数据库连接的示例代码:

public class JDBCDemo {public static void main(String[] args) {// JDBC连接参数String url = "jdbc:mysql://localhost:3306/mydatabase";String username = "root";String password = "password";try {// 建立数据库连接Connection connection = DriverManager.getConnection(url, username, password);// 在此处执行插入数据操作// 关闭连接connection.close();} catch (SQLException e) {e.printStackTrace();}}
}

步骤3:创建SQL插入语句

接下来,您需要创建一个SQL插入语句,以指定要插入的数据和目标表。SQL插入语句通常采用以下格式:

INSERT INTO table_name (column1, column2, column3, ...)
VALUES (value1, value2, value3, ...);

在上述SQL语句中,table_name是目标表的名称,column1column2等是要插入数据的列名,value1value2等是要插入的实际数据值。

步骤4:执行插入数据操作

要执行插入数据操作,您需要创建一个Statement对象,并使用它来执行SQL插入语句。以下是一个示例代码:

try {// 创建Statement对象Statement statement = connection.createStatement();// 创建SQL插入语句String sql = "INSERT INTO employees (name, salary) VALUES ('John', 50000)";// 执行SQL插入语句int rowsAffected = statement.executeUpdate(sql);if (rowsAffected > 0) {System.out.println("Insertion successful. Rows affected: " + rowsAffected);} else {System.out.println("Insertion failed.");}// 关闭Statementstatement.close();
} catch (SQLException e) {e.printStackTrace();
}

在上述代码中,我们创建了一个Statement对象,然后使用executeUpdate()方法执行SQL插入语句。通过检查rowsAffected变量,我们可以确定是否插入成功。

步骤5:关闭连接

最后,在插入数据操作完成后,不要忘记关闭数据库连接。这是释放资源和确保数据库安全性的重要步骤。

connection.close();

防止SQL注入攻击

在执行SQL插入操作时,务必注意防止SQL注入攻击。SQL注入攻击是一种恶意操作,通过在输入数据中注入恶意SQL代码,来绕过应用程序的安全措施,访问或破坏数据库。

为了防止SQL注入攻击,您应该使用参数化的SQL语句或预编译的语句。以下是一个使用预编译语句的示例:

try {// 创建预编译的SQL插入语句String sql = "INSERT INTO employees (name, salary) VALUES (?, ?)";PreparedStatement preparedStatement = connection.prepareStatement(sql);// 设置参数的值preparedStatement.setString(1, "John");preparedStatement.setInt(2, 50000);// 执行预编译的语句int rowsAffected = preparedStatement.executeUpdate();if (rowsAffected > 0) {System.out.println("Insertion successful. Rows affected: " + rowsAffected);} else {System.out.println("Insertion failed.");}// 关闭PreparedStatementpreparedStatement.close();
} catch (SQLException e) {e.printStackTrace();
}

在上述示例中,我们使用了PreparedStatement对象,并使用占位符?来表示参数。然后,通过调用setXXX()方法设置参数的值,其中XXX表示参数的数据类型。这种方式可以有效地防止SQL注入攻击。

异常处理

在编写插入数据操作时,应该注意处理可能出现的异常。通常,与数据库交互的代码都会抛出SQLException,因此您应该使用try-catch块来捕获并处理这些异常。

try {// 执行插入数据操作} catch (SQLException e) {e.printStackTrace();
}

在异常处理块中,您可以根据具体情况采取适当的措施,例如记录日志、回滚事务或提供错误消息给用户。

示例代码

以下是一个完整的示例代码,演示了如何使用JDBC插入数据到MySQL数据库:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;public class InsertDataExample {public static void main(String[] args) {// JDBC连接参数String url = "jdbc:mysql://localhost:3306/mydatabase";String username = "root";String password = "password";try {// 建立数据库连接Connection connection = DriverManager.getConnection(url, username, password);// 创建预编译的SQL插入语句String sql = "INSERT INTO employees (name, salary) VALUES (?, ?)";PreparedStatement preparedStatement = connection.prepareStatement(sql);// 设置参数的值preparedStatement.setString(1, "John");preparedStatement.setInt(2, 50000);// 执行预编译的语句int rowsAffected = preparedStatement.executeUpdate();if (rowsAffected > 0) {System.out.println("Insertion successful. Rows affected: " + rowsAffected);} else {System.out.println("Insertion failed.");}// 关闭连接和PreparedStatementpreparedStatement.close();connection.close();} catch (SQLException e) {e.printStackTrace();}}
}

请注意,上述代码中的数据库连接参数、表名、列名等应根据您的实际情况进行修改。

这就是使用JDBC插入数据的基本步骤和示例。通过遵循这些步骤,您可以安全地将数据插入到数据库中,同时避免了常见的SQL注入攻击。希望这篇文章对您理解JDBC插入操作有所帮助!如果您有任何疑问或需要进一步的帮助,请随时提出。

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

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

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

相关文章

CSS详细基础(六)边框样式

本期是CSS基础的最后一篇~ 目录 一.border属性 二.边框属性复合写法 三.CSS修改表格标签 四.内边距属性 五.外边距属性 六.其他杂例 1.盒子元素水平居中 2.清除网页内外元素边距 3.外边距的合并与塌陷 4.padding不会撑大盒子的情况 七.综合案例——新浪导航栏仿真 …

Android studio升级Giraffe | 2022.3.1 Patch 1踩坑

这里写自定义目录标题 not "opens java.io" to unnamed module错误报错信息解决 superclass access check failed: class butterknife.compiler.ButterKnifeProcessor$RScanner报错报错信息解决 Android studio升级Giraffe | 2022.3.1 Patch 1后,出现项目…

imgui开发笔记<1>、ubuntu环境下快速应用

去这个链接下载imgui源码(在此之前需要安装opengl glfw3等等): sudo apt-get install libglfw3-dev https://github.com/ocornut/imgui 我这里源码下载到/home/temp/imgui目录下,咱们不需要编译源码成库,而是直接将下…

【Axure高保真原型】3D圆柱图_中继器版

今天和大家分享3D圆柱图_中继器版的原型模板,图表在中继器表格里填写具体的数据,调整坐标系后,就可以根据表格数据自动生成对应高度的圆柱图,鼠标移入时,可以查看对应圆柱体的数据……具体效果可以打开下方原型地址体验…

网络安全渗透测试工具之skipfish

网络安全渗透测试工具skipfish介绍 在数字化的时代,Web 应用程序安全成为了首要任务。想象一下,您是一位勇敢的安全冒险家,迎接着那些隐藏在 Web 应用程序中的未知风险。而在这个冒险之旅中,您需要一款强大的工具来帮助您发现漏洞,揭示弱点。而这个工具就是 Skipfish。 …

LeetCode 周赛上分之旅 #48 一道简单的树上动态规划问题

⭐️ 本文已收录到 AndroidFamily,技术和职场问题,请关注公众号 [彭旭锐] 和 BaguTree Pro 知识星球提问。 学习数据结构与算法的关键在于掌握问题背后的算法思维框架,你的思考越抽象,它能覆盖的问题域就越广,理解难度…

点击、拖拉拽,BI系统让业务掌握数据分析主动权

在今天的商业环境中,数据分析已经成为企业获取竞争优势的关键因素之一。然而,许多企业在面对复杂的数据分析工具时,却常常感到困扰。这些工具往往需要专业的技术人员操作,而且界面复杂,难以理解和使用。对业务人员来说…

阿里云 Oss 权限控制

前言 最近公司的私有 Oss 服务满了,且 Oss 地址需要设置权限,只有当前系统的登录用户才能访问 Oss 下载地址。一开始想着用 Nginx 做个转发来着,Nginx 每当检测当前请求包含特定的 Oss 地址就转发到我们的统一鉴权接口上去,但是紧…

picoctf_2018_shellcode

picoctf_2018_shellcode Arch: i386-32-little RELRO: Partial RELRO Stack: No canary found NX: NX disabled PIE: No PIE (0x8048000) RWX: Has RWX segments32位,啥都没开 这个看着挺大的,直接来个ROPchain,…

Redis缓存穿透、击穿和雪崩

面试高频 服务的高可用问题! 在这里我们不会详细的区分析解决方案的底层! Redis缓存概念 Redis缓存的使用,极大的提升了应用程序的性能和效率,特别是数据查询方面。但同时,它也带来了一些问题。其中,最要…

Android stdio的Gradle菜单栏无内容问题的解决方法

右边Gradle菜单栏里没有Tasks选项内容的问题 正常情况↓ 如果这个问题如果无法解决的话,Gradle打包就只能通过控制台输入命令来解决,但这无疑是把简单问题复杂化了,我们来看看怎么解决这个问题吧。 这里有几个方法提供,可以自行选…

排序篇(四)----归并排序

排序篇(四)----归并排序 1.归并(递归) 基本思想: 归并排序(MERGE-SORT)是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide andConquer)的一个非常典型的应用。将已有序的子序列合并,得到…

leetCode 376.摆动序列 动态规划 + 图解 + 状态转移

376. 摆动序列 - 力扣(LeetCode) 如果连续数字之间的差严格地在正数和负数之间交替,则数字序列称为 摆动序列 。第一个差(如果存在的话)可能是正数或负数。仅有一个元素或者含两个不等元素的序列也视作摆动序列。 例如…

微信小程序引入字体在部分机型失效不兼容解决办法

写小程序页面,美工作图用了特殊字体 引入代码: font-face {font-family: huxiaobo;src: url("https://xxxxxxxx.top/assets/fonts/huxiaobonanshenti.woff") } .font-loaded {font-family: "huxiaobo"; } 上线后发现部分安卓机型不…

209. 长度最小的子数组(滑动窗口)

一、题目 209. 长度最小的子数组 - 力扣&#xff08;LeetCode&#xff09; 二、代码 class Solution { public:int minSubArrayLen(int target, vector<int>& nums) {int left 0, right 0;int sum nums[right];int MinLength INT_MAX;while (left <nums.siz…

计算机竞赛 深度学习火车票识别系统

文章目录 0 前言1 课题意义课题难点&#xff1a; 2 实现方法2.1 图像预处理2.2 字符分割2.3 字符识别部分实现代码 3 实现效果4 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 图像识别 火车票识别系统 该项目较为新颖&#xff0c;适…

54、数组--模拟

LCR 146. 螺旋遍历二维数组 给定一个二维数组 array&#xff0c;请返回「螺旋遍历」该数组的结果。 螺旋遍历&#xff1a;从左上角开始&#xff0c;按照 向右、向下、向左、向上 的顺序 依次 提取元素&#xff0c;然后再进入内部一层重复相同的步骤&#xff0c;直到提取完所有…

(vue3)create-vue 组合式APIsetup、ref、watch,通信

优势&#xff1a; 更易维护&#xff1a;组合式api&#xff0c;更好的TS支持 之前是选项式api&#xff0c;现在是组合式&#xff0c;把同功能的api集合式管理 复用功能封装成一整个函数 更快的速度 更小的体积 更优的数据响应式&#xff1a;Proxy create-vue 新的脚手架工…

【VIM】VIm-plug插件

如何查找需要的插件 https://github.com/mhinz/vim-startify https://github.com/vim-airline/vim-airline https://github.com/Yggdroot/indentLine github.com/w0ng/vim-hybrid github.com/altercationi/vim-colors-solarized guithub.com/morhetz/gruvbox github.com/sc…

PHP8的静态变量和方法-PHP8知识详解

我们在上一课程讲到了public、private、protected这3个关键字&#xff0c;今天我们来讲解static关键字&#xff0c;明天再讲解final关键字。 如果不想通过创建对象来调用变量或方法&#xff0c;则可以将该变量或方法创建为静态变量或方法&#xff0c;也就是在变量或方法的前面…