博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
DBUtils
阅读量:6261 次
发布时间:2019-06-22

本文共 2439 字,大约阅读时间需要 8 分钟。

DBUtils封装了对JDBC的操作,简化了JDBC操作,可以少写代码

 

两个类

QueryRunner中提供对sql语句操作的API.

ResultSetHandler接口,用于定义select操作后,怎样封装结果集.

 

QueryRunner核心类

l  update(Connection conn, String sql, Object... params) ,用来完成表数据的增加、删除、更新操作

l  query(Connection conn, String sql, ResultSetHandler<T> rsh, Object... params) ,用来完成表数据的查询操作

 

增加

//获取一个用来执行SQL语句的对象   QueryRunner

        QueryRunner qr = new QueryRunner();

       

        String sql = "INSERT INTO zhangwu(name,money,parent) VALUES(?,?,?)";

        Object[] params = {"股票收入", 5500, "收入"};

        Connection conn = JDBCUtils.getConnection();

        int line = qr.update(conn,sql,params);// 用来完成表数据的增加、删除、更新操作

        //结果集处理

        System.out.println("line = " + line);

        

删除

 

//创建一个QueryRunner对象,用来完成SQL语句的执行

        QueryRunner qr = new QueryRunner();

        //执行SQL语句

        String sql = "DELETE FROM zhangwu WHERE name = ?";

        Object[] params = {"股票收入"};

        Connection conn = JDBCUtils.getConnection();

        int line = qr.update(conn, sql, params);

        //结果集的处理

        System.out.println("line="+line);

   

 ResultSetHandler结果集处理类

  查询

Object[]  ArrayHandler------查询一条

List<Object[]> ArrayListHandler------查询

 

BeanHandler()

BeanListHandler() ----封装类的内容(所有)

 

//获取QueryRunner

            QueryRunner qr = new QueryRunner();

            //执行SQL语句

            String sql = "SELECT * FROM zhangwu WHERE id=?";

            Object[] params = {1};

            Connection conn = JDBCUtils.getConnection();

            ZhangWu zw = qr.query(conn, sql, new BeanHandler<ZhangWu>(ZhangWu.class), params);

            //结果集处理

            System.out.println(zw);

           

            conn.close();

 

//获取QueryRunner

            QueryRunner qr = new QueryRunner();

            //执行SQL语句

            String sql = "SELECT * FROM zhangwu WHERE money>?";

            Object[] params = {2000};

            Connection conn = JDBCUtils.getConnection();

            List<ZhangWu> list = qr.query(conn, sql, new BeanListHandler<ZhangWu>(ZhangWu.class), params);

 

 ColumnListHandler   ----取一列的数据

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

//获取QueryRunner对象

            QueryRunner qr = new QueryRunner();

            //执行SQL语句

            String sql = "SELECT name FROM zhangwu WHERE money>?";

            Object[] params = {2000};

            Connection conn = JDBCUtils.getConnection();

            List<String> list = qr.query(conn, sql, new ColumnListHandler<String>(), params);

            //结果集的处理

            for (String str : list) {

                System.out.println(str);

            }

 

            conn.close();

 

//获取QueryRunner对象

            QueryRunner qr = new QueryRunner();

           

            //执行SQL语句

            String sql = "SELECT MAX(money) FROM zhangwu";

            Object[] params = {};

            Connection conn = JDBCUtils.getConnection();

            Double max = qr.query(conn, sql, new ScalarHandler<Double>(), params);

            //结果集的处理

            System.out.println("max=" + max);

           

            conn.close();

转载于:https://www.cnblogs.com/1997WY/p/10703227.html

你可能感兴趣的文章
SSI框架总结
查看>>
应对通过代理攻击服务器的方法
查看>>
犀利的background-clip:text,实现K歌字幕效果
查看>>
SQL Server 错误18456
查看>>
u3d changeTexs
查看>>
Log4cpp介绍及使用
查看>>
Javascript Utils.js
查看>>
**PHP转义Json里的特殊字符的函数
查看>>
linux系统添加硬盘方法
查看>>
伯努利父子恩怨
查看>>
【RAC】 RAC For W2K8R2 安装--结尾篇(十)
查看>>
BZOJ-2115-Xor-WC2011
查看>>
Ehcache(02)——ehcache.xml简介
查看>>
JS中判定问题
查看>>
产品 线上 保持 和 支持 服务 (Support and maintenance solutions)
查看>>
React-Native入门指导之iOS篇 —— 一、准备工作
查看>>
std::string 不支持back
查看>>
不好的MySQL过程编写习惯
查看>>
使用nginx为ArcGIS Server做反向代理
查看>>
xpages的comboBox能够手动输入
查看>>