当前位置: 首页 > news >正文

基于JavaScript的DBUtils增删改查操作实验

1、实验目的

学习和掌握数据库连接池的配置与管理。使用DBUtils进行增删改查操作。按照步骤,掌握并实现使用DBUtils实现增删改查的全过程。

2、实验所用方法

     上机实践

3、实验步骤及截图

   创建一个数据库表,使用下面sql语句创建数据库表并插入数据:

CREATE TABLE USER(
id INT(3) PRIMARY KEY AUTO_INCREMENT,
NAME VARCHAR(20) NOT NULL,
PASSWORD VARCHAR(20) NOT NULL
);INSERT INTO USER(NAME,PASSWORD) VALUES ('zhangsan','123456');
INSERT INTO USER(NAME,PASSWORD) VALUES ('lisi','123456');
INSERT INTO USER(NAME,PASSWORD) VALUES ('wangwu','123456');

在项目chapter11的目录下,创建一个名为cn.itcast.jdbc.javabean的包,创建实体类User,用于封装User对象:

package cn.itcast.jdbc.javabean;
public class User {private int id;private String name;private String password;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}
}

在项目chapter11的src目录下,创建一个名为cn.itcast.jdbc.utils的包,然后在该包下创建C3p0Utils类,用于创建数据源:

package cn.itcast.jdbc.utils;
import javax.sql.DataSource;
import com.mchange.v2.c3p0.ComboPooledDataSource;
public class C3p0Utils {private static DataSource ds;static {ds = new ComboPooledDataSource();}public static DataSource getDataSource() {return ds;}
}

连接数据库不要忘记写JDBCUtils.java:

package cn.itcast.chapter11.example;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class JDBCUtils {// 加载驱动,并建立数据库连接public static Connection getConnection() throws SQLException,ClassNotFoundException {Class.forName("com.mysql.cj.jdbc.Driver");String url = "jdbc:mysql://localhost:3306/jdbc?serverTimezone=GMT%2B8";String username = "root";String password = "root";Connection conn = DriverManager.getConnection(url, username,password);return conn;}// 关闭数据库连接,释放资源public static void release(Statement stmt, Connection conn) {if (stmt != null) {try {stmt.close();} catch (SQLException e) {e.printStackTrace();}stmt = null;}if (conn != null) {try {conn.close();} catch (SQLException e) {e.printStackTrace();}conn = null;}}public static void release(ResultSet rs, Statement stmt,Connection conn){if (rs != null) {try {rs.close();} catch (SQLException e) {e.printStackTrace();}rs = null;}release(stmt, conn);}
}

在项目chapter11的src目录下,创建一个名为cn.itcast.jdbc.dao的包,然后在该包下创建一个InsertDao类,实现对user表插入数据的操作:

package cn.itcast.jdbc.dao;
import java.sql.SQLException;
import org.apache.commons.dbutils.QueryRunner;
import cn.itcast.jdbc.javabean.User;
import cn.itcast.jdbc.utils.C3p0Utils;
public class InsertDao {public static void main(String[] args)throws SQLException{// 创建QueryRunner对象QueryRunner runner = new QueryRunner(C3p0Utils.getDataSource());String sql = "insert into user (name,password) values ('hello1',123456)";int num = runner.update(sql);if (num > 0){System.out.println("添加成功!");}else{System.out.println("添加失败!");}}
}

文件InsertDao的运行结果:

在cn.itcast.jdbc.dao包下创建一个UpdateDao类,实现对user表数据的修改操作。UpdateDao类的实现如下所示:

package cn.itcast.jdbc.dao;
import cn.itcast.jdbc.javabean.User;
import cn.itcast.jdbc.utils.C3p0Utils;
import org.apache.commons.dbutils.QueryRunner;
import java.sql.SQLException;
public class UpdateDao {public static void main(String[] args)throws SQLException {// 创建QueryRunner对象QueryRunner runner = new QueryRunner(C3p0Utils.getDataSource());// 写SQL语句String sql = "update user set name='hello2',password=111111 where name='hello1'";// 调用方法int num = runner.update(sql);if (num > 0){System.out.println("修改成功!");}else{System.out.println("修改失败!");}}
}

文件UpdateDao的运行结果如下图所示:

在cn.itcast.jdbc.dao包下创建一个DeleteDao类,实现对user表数据的删除操作:

package cn.itcast.jdbc.dao;
import cn.itcast.jdbc.utils.C3p0Utils;
import org.apache.commons.dbutils.QueryRunner;
import java.sql.SQLException;
public class DeleteDao {public static void main(String[] args)throws SQLException {// 创建QueryRunner对象QueryRunner runner = new QueryRunner(C3p0Utils.getDataSource());// 写SQL语句String sql = "delete from user where name='hello2'";// 调用方法int num = runner.update(sql);if (num > 0){System.out.println("删除成功!");}else{System.out.println("删除失败!");}}
}

在cn.itcast.jdbc.dao包下创建一个QueryDao类,实现对user表中单条数据的查询操作:

package cn.itcast.jdbc.dao;
import cn.itcast.jdbc.javabean.User;
import cn.itcast.jdbc.utils.C3p0Utils;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;import java.sql.SQLException;
import java.util.List;public class QueryDao {public static void main(String[] args)throws SQLException {// 创建QueryRunner对象QueryRunner runner = new QueryRunner(C3p0Utils.getDataSource());// 写SQL语句String sql = "select * from user where id=2";// 调用方法User user = (User) runner.query(sql,new BeanHandler(User.class));System.out.println(user.getId()+","+user.getName()+","+user.getPassword());}
}

修改后:

package cn.itcast.jdbc.dao;
import cn.itcast.jdbc.javabean.User;
import cn.itcast.jdbc.utils.C3p0Utils;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;import java.sql.SQLException;
import java.util.List;public class QueryDao {public static void main(String[] args)throws SQLException {// 创建QueryRunner对象QueryRunner runner = new QueryRunner(C3p0Utils.getDataSource());// 写SQL语句String sql = "select * from user";// 调用方法List<User> list = (List) runner.query(sql,new BeanListHandler(User.class));for(User user : list){System.out.println(user.getId()+","+user.getName()+","+user.getPassword());}}
}

4、实验过程中出现的问题

在实验过程中,我遇到了一些挑战,如配置参数不合理导致连接池性能下降、SQL语句编写错误导致操作失败等。但通过不断调试和修改,我逐渐克服了这些困难,并成功实现了预期的实验目标。

5、实验心得

在本次实验中,我深入学习了数据库连接池的配置与管理,并掌握了使用DBUtils进行增删改查操作的全过程。通过实际操作,我对数据库连接池的工作原理和DBUtils的便捷性有了更深刻的理解。

实验初期,我首先了解了数据库连接池的基本概念和作用。连接池能够显著提高数据库的访问效率,减少数据库连接的建立和销毁次数,从而优化系统性能。随后,我学习了如何配置和管理数据库连接池,包括设置连接池的大小、连接超时时间等关键参数。

在掌握了数据库连接池的基础知识后,我开始学习DBUtils的使用。DBUtils是一个简化JDBC编程的工具类库,它提供了对数据库操作的封装,使开发者能够更加便捷地进行数据库操作。我通过查阅文档和示例代码,逐步掌握了DBUtils的使用方法,并实现了对数据库的增删改查操作。

通过这次实验,我深刻体会到了理论与实践相结合的重要性。只有将所学知识应用到实际操作中,才能真正理解和掌握。同时,我也认识到了自己在数据库管理方面的不足之处,如对于复杂SQL语句的编写和调优还需要进一步加强学习。

展望未来,我将继续深入学习数据库管理相关知识,不断提升自己的专业技能水平,为未来的职业发展打下坚实的基础。

 


 

http://www.lryc.cn/news/506502.html

相关文章:

  • 初学stm32 --- 系统时钟配置
  • 实现星星评分系统
  • 数据库建模工具 PDManer
  • 后台运维操作建议
  • NX二次开发调用内部函数设置对象穿透显示DSS_ATTR_set_show_through
  • ubuntu16.04ros-用海龟机器人仿真循线系统
  • 解决Ubuntu 20.04上编译OpenCV 3.2时遇到的stdlib.h缺失错误
  • HTML综合案例
  • TanStack——为现代前端开发提供高性能和灵活的工具
  • Java爬虫️ 使用Jsoup库进行API请求有什么优势?
  • React源码02 - 基础知识 React API 一览
  • COMSOL with Matlab
  • 【报表查询】.NET开源ORM框架 SqlSugar 系列
  • PostgreSQL数据库访问限制详解
  • 【test linux】创建一个ext4类型的文件系统
  • 如何在繁忙的生活中找到自己的节奏?
  • AI-PR曲线
  • Guava 提供了集合操作 `List`、`Set` 和 `Map` 三个工具类
  • 深入解析 Elasticsearch 集群配置文件参数
  • WebMvcConfigurer和WebMvcConfigurationSupport(MVC配置)
  • 用 javascript 来回答宇宙外面是什么
  • 我的性能优化经验
  • XSLT 编辑 XML
  • 数智读书笔记系列010 生命3.0:人工智能时代 人类的进化与重生
  • Transfomer的各层矩阵
  • 代码随想录第51天
  • 基础库httpx的使用
  • c++中如何保持结构体的线程安全?3D坐标的线程安全:从理论到最优解
  • Zabbix6.0升级为6.4
  • 答题考试系统v1.6.1高级版源码分享+uniapp+搭建测试环境