• 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);

        }

  • 相关阅读:
    python json模块 pickli模块
    python sys模块
    python os模块
    python random模块使用
    react项目搭建
    PHP开发环境及搭建
    Vue2之页面 、js 、css分离
    Component template should contain exactly one root element. If you are using v-if on multiple elements, use v-else-if to chain them instead.
    Uncaught Error: Bootstrap's JavaScript requires jQuery
    Mongoose: mpromise (mongoose's default promise library) is deprecated, plug in your own promise library instead: http://mongoosejs.com/docs/promises.html
  • 原文地址:https://www.cnblogs.com/masterhxh/p/12877148.html
Copyright © 2020-2023  润新知