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

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

DBUtils

DBUtils:连接数据库对象----jdbc辅助方法的集合类,线程安全。

作用:控制连接,控制驱动加载类。

 

QueryRunner:SQL语句的操作对象,可以设置查询结果集的封装策略,线程安全。

2:QueryRunner:SQL语句的操作对象,可以设置查询结果集的封装策略,线程安全。      构造方法:      (1)QueryRunner():创建一个与数据库无关的QueryRunner对象,后期再操作数据库的会后,需要手动给一个Connection对象,它可以手动控制事务。                Connection.setAutoCommit(false);     设置手动管理事务                Connection.commit();     提交事务      (2)QueryRunner(DataSource ds):创建一个与数据库关联的queryRunner对象,后期再操作数据库的时候,不需要Connection对象,自动管理事务。                DataSource:数据库连接池对象。      构造函数与增删改查方法的组合: QueryRunner()       update(Connection conn, String sql, Object... params)       query(Connection conn, String sql, ResultSetHandler
rsh, Object... params) QueryRunner(DataSource ds) update(String sql, Object... params) query(String sql, ResultSetHandler
rsh, Object... params)

  

DBUtils进行修改操作

//1.创建QueryRunner的实现类    QueryRunner queryRunner = new QueryRunner();    @Test    public void testQueryRunnerUpdate(){           //2.使用其update方法        String sql = "delete from account where id in(?,?)";        Connection conn = null;        try {            conn = Methods.getConnection();            //2.使用update方法            queryRunner.update(conn,sql,12,13);        } catch (Exception e) {            e.printStackTrace();        } finally {            Methods.release(null,conn,null);        }    }

  

DBUtils进行查询操作

 

(3)ResultSetHandle:封装数据的策略对象------将封装结果集中的数据,转换到另一个对象
策略:封装数据到对象的方式(示例:将数据库保存在User、保存到数组、保存到集合)
方法介绍:handle(ResultSet rs)

QueryRunner的query方法的返回值取决于ResultSetHandler参数的handle方法的返回值

 

//1.创建QueryRunner的实现类    QueryRunner queryRunner = new QueryRunner();    class MyResultSetHandler implements ResultSetHandler{        @Override        public Object handle(ResultSet resultSet) throws SQLException {            List
accounts = new ArrayList<>(); while(resultSet.next()){ Integer id = resultSet.getInt(1); String name = resultSet.getString(2); String password = resultSet.getString(3); Integer balance = resultSet.getInt(4); Account account = new Account(id,name,password,balance); accounts.add(account); } return accounts; } } @Test public void testQueryRunnerQuery(){ Connection conn = null; try { conn = Methods.getConnection(); String sql = "select id,name,password,balance from account"; Object obj = queryRunner.query(conn,sql,new MyResultSetHandler()); System.out.println(obj);//xxx } catch (Exception e) { e.printStackTrace(); } finally { Methods.release(null,conn,null); } }}

 

  

 BeanHandler():获取一条记录

 

/**     * BeanHandler:把结果集的第一条记录转换为创建BeanHandler对象时传入的Class参数对应的对象。     */    @Test    public void testBeanHandler(){        Connection conn = null;        try {            conn = Methods.getConnection();            String sql = "select * from account where id>=?";            Account account = (Account) queryRunner.query(conn,sql,new BeanHandler(Account.class),5);            System.out.println(account);        } catch (Exception e) {            e.printStackTrace();        } finally {        }    }

 

 

BeanListHandler:获取一组记录

/**     * BeanListHandler:把结果集转为一个List,该List不为null,但可能为空集合(size(() 方法返回0)     * 若SQL语句的确能够查询到记录,list中存放创建BeanListHandler传入的Class对象对应的对象。     */    @Test    public void testBeanListHandler() {        Connection conn = null;        try {            conn = Methods.getConnection();            String sql = "select * from account";            List
accounts = (List
) queryRunner.query(conn, sql, new BeanListHandler(Account.class)); System.out.println(accounts); } catch (Exception e) { e.printStackTrace(); } finally { } }

  

MapHandler

/**     * MapHandler:返回SQL对应的第一条记录对应Map对象     * 键:SQL查询的列名(不是列的别名),值:列的值     */    @Test    public void testMapHandler(){        Connection conn = null;        try {            conn = Methods.getConnection();            String sql = "select * from account";            Map
result = queryRunner.query(conn, sql, new MapHandler()); System.out.println(result); } catch (Exception e) { e.printStackTrace(); } finally { } }

MapListHandler

/**     * MapListHandler:将结果集转为一个Map的List     * Map对应查询一条记录:键:SQL查询的列名(不是列的别名),值:列的值     * 而MapListHandler:返回多条记录对应的Map的集合     */    @Test    public void testMapListHandler(){        Connection conn = null;        try {            conn = Methods.getConnection();            String sql = "select * from account";            List
> result = queryRunner.query(conn, sql, new MapListHandler()); System.out.println(result); } catch (Exception e) { e.printStackTrace(); } finally { } }

ScalarHandler

/**     * ScalarHandler:把结果集转为一个数值(可以是任意基本数据类型和字符串,Date等)返回     */    @Test    public void testScalarHandler(){        Connection conn = null;        try {            conn = Methods.getConnection();            String sql = "select name from account where id =?";            Object result =  queryRunner.query(conn, sql, new ScalarHandler(),5);            System.out.println(result);        } catch (Exception e) {            e.printStackTrace();        } finally {        }    }

  

 

转载于:https://www.cnblogs.com/yangHS/p/10846580.html

你可能感兴趣的文章
03-k8s-master
查看>>
我的友情链接
查看>>
Linux Centos的Inode及Block相关知识
查看>>
Zabbix server 搭建
查看>>
ehcache实例
查看>>
《ERP项目管理散记》第二章(科学估算—— 应用PERT估计项目工期)
查看>>
Code::Blocks设定相关
查看>>
PL/SQL基础篇10(trigger)
查看>>
Spring Security权限框架理论与简单Case
查看>>
Invalid icc profile: duplicate sequence numbers
查看>>
day1
查看>>
开源中国的 IT 公司开源软件整理计划介绍
查看>>
DDoS deflate - Linux下防御/减轻DDOS***
查看>>
关于outlook2007在WIN7下收取邮件很慢的解决办法
查看>>
Android第三十七天
查看>>
VMM2012应用指南之13- 自助服务门户网站的使用
查看>>
GraphQL入门
查看>>
IBM Java多线程 - 1. 线程基础
查看>>
3月7日高项作业(信息化基础和信息系统服务管理)
查看>>
【C++探索之旅】第一部分第六课:控制流程,随心所至
查看>>