JavaWeb学习-JDBC系列-8-基于DBUtils工具类的CRUD练习

2024-06-11 11:08

本文主要是介绍JavaWeb学习-JDBC系列-8-基于DBUtils工具类的CRUD练习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前面我们封装了一个用于连接数据库和关闭资源的DBUtils的类,可以减少很多重复的代码。这个类,提供了连接数据库和关闭资源的两个静态方法。再次复习下这个类中加载properties文件,为什么要使用静态代码块,也就是static{},因为我们想,这个DBUtils类一加载到JVM虚拟机就里面执行加载解析propertes文件操作。这个技巧,我们之前在Selenium自动化中写driver的初始化也用上了。

1.数据表准备

为了我们下一篇的练习,这里我给这个student表新增一个password字段,也就是学生密码,方便我们后面文章来做登录练习。

执行sql语句或者小海豚上图形界面操作。

alter table student add pwd char(20);

我这里随机给当前已有学生添加密码

2.查询练习

这个我们在前面一篇文章的练习之后,把查询的结果集封装成Student对象,这里新加了一个字段,所以,我们的Student.java里面也需要新加一个private String password 和set get方法。

package demo;import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;import org.junit.Test;import com.anthony.utils.DBUtils;public class CURD {@Testpublic void testSelect() {Connection conn = null;Statement stmt = null;ResultSet rs = null;try {conn = DBUtils.getConnection();stmt = conn.createStatement();rs = stmt.executeQuery("SELECT * FROM student");List<Student> list = new ArrayList<Student>();while(rs.next()) {Student s = new Student();s.setName(rs.getString("Name"));s.setId(rs.getInt("ID"));s.setGender(rs.getString("Gender"));s.setAge(rs.getInt("Age"));s.setPassword(rs.getString("pwd"));// 把student对象添加到集合中list.add(s);}//遍历集合for (Student student : list) {System.out.println(student.toString());}} catch (Exception e) {e.printStackTrace();} finally {DBUtils.close(conn, stmt, rs);}}
}

测试结果:


Student [Id=192101, Name=Tom, Gender=male, Age=19, password=123]
Student [Id=192102, Name=Lucy, Gender=female, Age=18, password=456]
Student [Id=192103, Name=Dniel, Gender=male, Age=20, password=111]
Student [Id=192104, Name=Sunny, Gender=female, Age=18, password=2222]
Student [Id=192105, Name=Anthony, Gender=male, Age=23, password=123456]

3.插入练习

这里我直接贴单元测试代码

@Test
public void testInsert() {Connection conn = null;Statement stmt = null;try {conn = DBUtils.getConnection();stmt = conn.createStatement();int i = stmt.executeUpdate("INSERT INTO student VALUES ('192106','Lisi','male','22','333')");if (i > 0) {System.out.println("插入成功");}} catch (Exception e) {e.printStackTrace();} finally {DBUtils.close(conn, stmt, null);}
}

4.更新练习

这里,我把Anthony的年龄从23改成18.

        @Testpublic void testUpdate() {Connection conn = null;Statement stmt = null;try {conn = DBUtils.getConnection();stmt = conn.createStatement();int i = stmt.executeUpdate("UPDATE student SET Age='18' WHERE Name='Anthony'");if (i > 0) {System.out.println("更新成功");}} catch (Exception e) {e.printStackTrace();} finally {DBUtils.close(conn, stmt, null);}}

刷新一下小海豚,或者执行上面查询的用例。

5.删除练习

这里我把Tom这行数据删除

        @Testpublic void testDelete() {Connection conn = null;Statement stmt = null;try {conn = DBUtils.getConnection();stmt = conn.createStatement();int i = stmt.executeUpdate("DELETE FROM student WHERE Name='Tom'");if (i > 0) {System.out.println("删除成功");}} catch (Exception e) {e.printStackTrace();} finally {DBUtils.close(conn, stmt, null);}}

结果Tom被删除

这篇关于JavaWeb学习-JDBC系列-8-基于DBUtils工具类的CRUD练习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1050992

相关文章

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

一文详解SpringBoot中控制器的动态注册与卸载

《一文详解SpringBoot中控制器的动态注册与卸载》在项目开发中,通过动态注册和卸载控制器功能,可以根据业务场景和项目需要实现功能的动态增加、删除,提高系统的灵活性和可扩展性,下面我们就来看看Sp... 目录项目结构1. 创建 Spring Boot 启动类2. 创建一个测试控制器3. 创建动态控制器注

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

java中反射Reflection的4个作用详解

《java中反射Reflection的4个作用详解》反射Reflection是Java等编程语言中的一个重要特性,它允许程序在运行时进行自我检查和对内部成员(如字段、方法、类等)的操作,本文将详细介绍... 目录作用1、在运行时判断任意一个对象所属的类作用2、在运行时构造任意一个类的对象作用3、在运行时判断

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文