DBUtils的使用方法

DBUtils的使用方法
使用DbUtils的第一步,导入相关jar包:

驱动jar包与dbutils的工具jar包,缺一不可。

1、创建工程,导入相关jar包,然后add to build path

2、使用DbUtils完成数据库操作

步骤:

获取数据库连接

创建QueryRunner对象

使用QueryRunner对象执行sql语句

处理结果

释放资源

第一步获取连接中包含了加载驱动、获取连接,所以本质上还是六步操作!

(1) 、添加操作

//添加操作

public static void insertDemo() {

    //1、获取数据库连接

    Connection connection = JDBCUtils.getConnection();

    //2、创建QueryRunner核心对象,替换了原生jdbc的语句平台

    QueryRunner qRunner = new QueryRunner();

    //3、执行sql语句

    /*

        QueryRunner对象在执行增删改语句时,方法都是update()

        update()方法的返回值是整型数字,代表影响的记录条数

        update()方法此时需要传入连接对象,虽然有六个重载方法,我们只需要记住两个即可

        update(connection, sql) 此方法的sql语句中不能使用?来代替值

        update(connection, sql, 可变参数) 此方法中的sql可以使用?来代替值,因为可以传入绑定的参数!

     */

    try {

        //无参方法的演示

        //int row = qRunner.update(connection, "insert into user values (null, '王豫川', '222', '男')");

       

        /*

            可变参数 Object... 代表参数是动态数量,也就是参数个数不确定!

            可变参数的传递方式:

            1、直接传数组。Object[],在数组中为?挨个填写对应的值,要保证?的个数与值的个数一致,

            值的类型要与?替代的类型一致

            2、将参数挨个书写,使用逗号隔开,但是要注意的是,值的个数与?个数一致,而且类型也得一致

            推荐使用第二种!!!

         */

        //有参方法的演示

        /*

        Object[] objs = {"小哈", "438", "男"};

        int row = qRunner.update(connection, "insert into user values (null, ?, ?, ?)", objs);*/

        int row = qRunner.update(connection, "insert into user values (null, ?, ?, ?)",

                                            "骚超", "333", "女");

        System.out.println(row > 0 ? "添加成功" : "添加失败");

    } catch (SQLException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

    } finally {

        //释放资源

        try {

            DbUtils.close(connection);

        } catch (SQLException e) {

            // TODO Auto-generated catch block

            e.printStackTrace();

        }

    }

}

(2) 、删除操作

//删除操作

public static void deleteDemo() throws SQLException {

    Connection connection = JDBCUtils.getConnection();

    QueryRunner qRunner = new QueryRunner();

    int row = qRunner.update(connection, "delete from user where uid = ?", 10);

    System.out.println(row > 0 ? "删除成功" : "删除失败");

    DbUtils.close(connection);

}

(3) 、修改操作

//修改操作

public static void updateDemo() {

    Connection connection = JDBCUtils.getConnection();

    QueryRunner qRunner = new QueryRunner();

    try {

        int row = qRunner.update(connection, "update user set uname = ?, pwd = ?, gender = ? where uid = ?",

                                    "馊丸子", "222", "女", 2);

        System.out.println(row > 0 ? "修改成功" : "修改失败");

    } catch (SQLException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

    } finally {

        try {

            DbUtils.close(connection);

        } catch (SQLException e) {

            // TODO Auto-generated catch block

            e.printStackTrace();

        }

    }

}

(4)、查询操作

查询结果集封装的接口为ResultSetHandler

这个接口有八大实现类:

ArrayHandler

将结果集中的第一条记录封装到一个Object[]数组中,数组中的每一个元素就是这条记录中的每一个字段的值

ArrayListHandler

将结果集中的每一条记录都封装到一个Object[]数组中,将这些数组在封装到List集合中。

BeanHandler

将结果集中第一条记录封装到一个指定的javaBean中。

BeanListHandler

将结果集中每一条记录封装到指定的javaBean中,将这些javaBean在封装到List集合中

ColumnListHandler

将结果集中指定的列的字段值,封装到一个List集合中

ScalarHandler

它是用于单数据。例如select count(*) from 表操作。

MapHandler

将结果集第一行封装到Map集合中,Key 列名, Value 该列数据

MapListHandler

将结果集每一行封装到Map集合中,Key 列名, Value 该列数据,Map集合存储到List集合

示例代码:

//查询操作

/*

    将结果集中第一条记录封装到一个指定的javaBean中

    javaBean 是java类的设计规范:

    当我们在设计实体类(model类,存储数据)时,需要注意以下几条规则:

    1、类必须是public修饰

    2、属性必须私有化

    3、私有化属性必须提供setter、getter方法

    4、必须保证类中无参构造的存在

 */

public static void beanHandlerDemo() {

    Connection connection = JDBCUtils.getConnection();

    QueryRunner qRunner = new QueryRunner();

    /*

        QueryRunner对象在执行查询sql时,需要使用query()方法

        此时需要传入连接对象,只需要记住两个重载方法即可

        query(connection, sql, 结果集实现类) 此方法中的sql不支持?绑定数据

        query(connection, sql, 结果集实现类, 可变参数) 此方法中的sql支持?绑定数据

     */

    try {

        /*

            结果集在创建对象时,需要指定对象泛型以及对象类的类对象(反射)

            反射此时做的事情:

            1、通过反射可以找到类中的无参构造,来创建对象

            2、通过反射找到了setter方法,完成了对象中每一个属性的赋值(赋值的内容就是表中字段的内容)

            但是我们在使用时,一定要注意的问题是:

            1、必须保证无参构造存在,如果没有无参构造,创建不了对象,直接崩溃

            2、为了保证属性赋值的成功,属性名必须与表中字段名一致!!!

         */

        User user = qRunner.query(connection, "select * from user where uid = ?",

                                new BeanHandler<User>(User.class), 3);

        System.out.println(user);

    } catch (SQLException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

    } finally {

        try {

            DbUtils.close(connection);

        } catch (SQLException e) {

            // TODO Auto-generated catch block

            e.printStackTrace();

        }

    }

}

/*

    BeanListHandler

    将结果集中每一条记录封装到指定的javaBean中,将这些javaBean在封装到List集合中

 */

public static void beanListHandlerDemo() throws SQLException {

    Connection connection = JDBCUtils.getConnection();

    QueryRunner qRunner = new QueryRunner();

    List<User> users = qRunner.query(connection, "select * from user", new BeanListHandler<User>(User.class));

    for (User user : users) {

        System.out.println(user);

    }

    DbUtils.close(connection);

}

/*

    ScalarHandler

    它是用于单数据(聚合函数)。例如select count(*) from 表操作。

 */

public static void scalarHandlerDemo() throws SQLException {

    Connection connection = JDBCUtils.getConnection();

    QueryRunner qRunner = new QueryRunner();

    long count = (Long)qRunner.query(connection, "select count(*) from user", new ScalarHandler());

    count = (int)count;

    System.out.println("总用户量为:" + count);

    DbUtils.close(connection);

}

/*

    ArrayHandler

    将结果集中的第一条记录封装到一个Object[]数组中,数组中的每一个元素就是这条记录中的每一个字段的值

 */

public static void arrayHandlerDemo() throws SQLException {

    Connection connection = JDBCUtils.getConnection();

    QueryRunner qRunner = new QueryRunner();

    Object[] objs = qRunner.query(connection, "select * from user where uid = ?",

                    new ArrayHandler(), 1);

    for (Object object : objs) {

        System.out.println(object);

    }

    DbUtils.close(connection);

}

/*

    ColumnListHandler

    将结果集中指定的列的字段值,封装到一个List集合中

 */

public static void columnListHandlerDemo() throws SQLException {

    Connection connection = JDBCUtils.getConnection();

    QueryRunner qRunner = new QueryRunner();

    List<Object> list = qRunner.query(connection, "select uname from user", new ColumnListHandler());

    for (Object object : list) {

        System.out.println(object);

    }

    DbUtils.close(connection);

}

/*

    MapListHandler

    将结果集每一行封装到Map集合中,Key 列名, Value 该列数据,Map集合存储到List集合

 */

public static void mapListHandlerDemo() throws SQLException {

    Connection connection = JDBCUtils.getConnection();

    QueryRunner qRunner = new QueryRunner();

    List<Map<String, Object>> list = qRunner.query(connection, "select * from user", new MapListHandler());

    for (Map<String, Object> map : list) {

        Set<String> set = map.keySet();

        for (String key : set) {

            System.out.print(map.get(key) + "--");

        }

        System.out.println();

    }

    DbUtils.close(connection);

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值