代码编织梦想

实验名称:

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

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/Liwo4418/article/details/129669977

网络编程-爱代码爱编程

网络编程 网络编程一、什么是网络二、计算机网络三、网络编程四、网络模型(OSI模型)五、TCP/IP模型六、TCP\UDP协议七、IP八、Port端口九、InetAddress类十、网络编程10.1 Socket编程