JavaWeb——使用DBUtils实现数据库的增删改查操作
创始人
2025-05-31 12:58:38
0

实验名称:

使用DBUtils实现数据库的增删改查操作                                                   

实验目的:

(1)了解什么是数据库连接池,会使用DBCP和C3P0数据源

(2)了解DBUtils工具中常见的API

(3)学会用DBUtils工具对数据进行增删改查的操作

实验内容及原理:

建立数据库和表,使用数据库连接池技术和DBUtils实现对进行数据库增删改查操作。

要求:

(1)在JDBC的基本操作中,由于每操作一次数据库,都会执行一次创建和断开Connection对象的操作,频繁的操作Connection对象十分影响数据库的访问效率,并且增加了代码量。在实际开发中,开发人员通常会使用数据库连接池来解决这些问题。使用数据连接池技术可以减少创建和断开数据库连接的次数,提高数据库的访问效率。Apache组织还提供了一个DBUtils工具类库,该类库实现了对JDBC的简单封装,能在不影响性能的情况下极大地简化JDBC的编码工作量。

(2)建立jdbc数据库,建立users数据表,包含id,name,password属性,输入记录,使用DBUtils数据库jdbc的增删改查操作。

(3)加载Junit4测试单元进行测试。

实验设备及实验步骤:

1.将建立好的users表进行截图,粘贴在下方。

2.在项目中添加c3p0的jar包和c3p0-config.xml文件,并构建路径 ,截取项目结构图粘贴在下方

3.建立DBUtilsDao类,并在其中建立插入一条记录的方法

代码如下:

public class DBUtilsDao {@Testpublic void testInsert() throws SQLException {//1 建立数据源ComboPooledDataSource dataSource = new ComboPooledDataSource();//2 创建DBUtils中的QueryRunner对象QueryRunner queryRunner = new QueryRunner(dataSource);//3 增加记录queryRunner.update("insert into user value(null,?,?)","Jerry","abc111");queryRunner.update("insert into user value(null,?,?)","Tony","xyz222");}

4、在DBUtilsDao类中建立修改记录的方法

代码如下:

@Test
public void testUpdate() throws SQLException {//1 建立数据源ComboPooledDataSource dataSource = new ComboPooledDataSource();//2 创建DBUtils中的QueryRunner对象QueryRunner queryRunner = new QueryRunner(dataSource);//3 修改更新queryRunner.update("update user set password=? where id=?","abc222",2);
}

5、在DBUtilsDao类中建立删除记录的方法

代码如下:

  @Testpublic void testDelete() throws SQLException {//1 建立数据源ComboPooledDataSource dataSource = new ComboPooledDataSource();//2 创建DBUtils中的QueryRunner对象QueryRunner queryRunner = new QueryRunner(dataSource);//3 删除记录queryRunner.update("delete from user where id=? ",1);}

6、在DBUtilsDao类中建立查询记录的方法

代码如下:
 

  @Testpublic void testSelect() throws SQLException {//1 建立数据源ComboPooledDataSource dataSource = new ComboPooledDataSource();//2 创建DBUtils中的QueryRunner对象QueryRunner queryRunner = new QueryRunner(dataSource);//3 查询单个对象User user1 =queryRunner.query("select * from user where id=?",new BeanHandler(User.class),2);System.out.println(user1.toString());}
}

7、运行结果图截图:

(1)运行testInsert()方法。

(2)运行testUpdate()方法。

(3)运行testDelete()方法。

(4)运行testSelect()方法。

问题及思考:

通过本次学习,我掌握了建立数据库和表,能够独立完成使用数据库连接池技术和DBUtils实现对进行数据库增删改查操作。在完成该项目时遇到了查询的时候不出现密码,经过调整User类的password的getPassword()和setPassword()方法后,正常出现密码。

相关内容

热门资讯

捐款感谢信的范文参照 感谢村民... 捐款感谢信的范文一尊敬的xx实验中学的全体师生、员工:  您们好!您们的捐款我们如数收到,您们的爱心...
最新或2023(历届)火灾捐款...  火灾捐款感谢信范文一:同志:  正月初七早晨,新河镇西门街遭受火灾,一排木结构二层七间民房着火,居...
毕业送给给老师的感谢信 六年级... 尊敬的老师:  你好!感谢这三年来你对我的关怀与照顾,在你的帮助下,我也考得了好成绩,我之所以能考到...
最新或2023(历届)给老师的...   给老师的感谢信范文参考一敬爱的老师:  您好!最近在课堂上看到您容光满面,我也替您感到快乐与舒心...
家长写给老师的感谢信范文精选 ... 泾洋初级中学的老师、同学们:  我是贵校初三第十三班学生陈佳豪的家长。就在清明节放假期间,我的孩子在...
【vue2】vue2中的性能优... ⭐ v-for 遍历避免同时使用 v-if ⭐ v-for 中的key绑定唯一的值 ⭐ v-show...
freemarker转成PDF... Spring Boot 集成 FreeMarker 可以通过在 pom.xml 文件中添加依赖项来实...
写给亲爱的妈妈的一封感谢信 给... 写给亲爱的妈妈的一封感谢信亲爱的妈妈:  您好!  恩情,从小处讲可以是炎夏中给你一碗清爽冰凉的柠檬...
受到爱心捐款的感谢信范文 受灾... 受到爱心捐款感谢信一尊敬的老师,亲爱的同学: 你们好!  自9月xx日校工会、校团委发出向后港小学陈...
关于国家助学金感谢信范文 关于... 关于国家助学金感谢信篇一  尊敬的各位领导、老师:  你们好!  我很高兴能向国家和学校申请国家助学...
最新或2023(历届)助学金获...  助学金获奖感谢信范文篇一:  首先,感谢国家对我们贫困大学生的关怀和关爱。  xxxx年10月份我...
关于拾金不昧的感谢信精选范文 ... 拾金不昧的感谢信范文篇一  尊敬的县保健院领导及全体员工:  我叫XXX,于20XX年2月17日下午...
Java String字符串和... String 在编程中被广泛使用,所以掌握 String 和 int 的相互转换方法是...
暗夜发光,独自闪耀,盘点网页暗... 众所周知,网页的暗黑模式可以减少屏幕反射和蓝光辐射,减少眼睛的疲劳感&#...
周一早会主持词 周一早会主持词... 周一早会主持词  、爱我中华  爱家、爱厂、爱中华,五十六个民族是一家。下面请欣赏检验班带给我们的《...
生日庆典主持词 生日庆典主持词... 生日庆典主持词  各位亲朋、各位来宾:  大家中午好!   在这里,我受主人之托,以尽主持之礼,由于...
历史的追忆主持词 历史的追忆主... 历史的追忆主持词  历史的长河远远流淌,如同我们身上流淌着的同血缘,让我们从四面八方相聚在这里。今天...
亲子运动会主持词 亲子运动会主... 亲子运动会主持词  一、开场台词  尊敬的各位激、亲爱的小朋友们,大家下午好:   在这片片红叶飞来...
庆国庆晚会主持词 庆国庆晚会主... 庆国庆晚会主持词  男:尊敬的各位领导,各位来宾、老师、同学,  合:大家晚上好!我是今晚的主持人\...
举一反三学python(2)—... Con_Info = ["王伟(男),河南郑州, 137****8331","杨秀娟(女),...