实验名称:
使用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 {
@Test
public 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类中建立删除记录的方法
代码如下:
@Test
public 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类中建立查询记录的方法
代码如下:
@Test
public 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>(User.class),2);
System.out.println(user1.toString());
}
}
7、运行结果图截图:
(1)运行testInsert()方法。
(2)运行testUpdate()方法。
(3)运行testDelete()方法。
(4)运行testSelect()方法。
问题及思考:
通过本次学习,我掌握了建立数据库和表,能够独立完成使用数据库连接池技术和DBUtils实现对进行数据库增删改查操作。在完成该项目时遇到了查询的时候不出现密码,经过调整User类的password的getPassword()和setPassword()方法后,正常出现密码。