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

实验名称:

使用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()方法后,正常出现密码。

相关内容

热门资讯

王毅在云南玉溪会见柬埔寨副首相... 12月28日,中共中央政治局委员、外交部长王毅在云南玉溪会见柬埔寨副首相兼外交大臣布拉索昆。王毅表示...
辽阳重大火灾事故调查发布 (来源:环球时报)转自:环球时报 【#辽阳重大火灾事故调...
总投资23亿元!又一个年产2.... (来源:石墨邦)据古田县融媒体中心消息,近日,福建省宁德市古田县国企与中林绿安(上海)科贸发展有限公...
中国神华(01088):北海二... 中国神华(01088)发布公告,近日,公司持股约52%的控股子公司国能广投北海发电有限公司(“北海电...
杭州机场年旅客吞吐量首破500... 格隆汇12月28日|据中新网,今日,GJ8008航班停靠停机坪。随着长龙航空GJ8008航班平稳降落...