使用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测试单元进行测试。
代码如下:
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");}
代码如下:
@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);
}
代码如下:
@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);}
代码如下:
@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());}
}
(1)运行testInsert()方法。
(2)运行testUpdate()方法。
(3)运行testDelete()方法。
(4)运行testSelect()方法。
通过本次学习,我掌握了建立数据库和表,能够独立完成使用数据库连接池技术和DBUtils实现对进行数据库增删改查操作。在完成该项目时遇到了查询的时候不出现密码,经过调整User类的password的getPassword()和setPassword()方法后,正常出现密码。