DbUtils是Apache组织提供的一个对JDBC进行简单封装的开源工具类库,使用它能够简化JDBC应用程序的开发,同时也不会影响程序的性能。

使用步骤:

A: 获取可以执行SQL语句的对象.
public QueryRunner();
public QueryRunner(DataSource ds); //如果需要用到连接池对象了, 会自动从数据库连接池中获取. B: 执行SQL语句, 获取结果集.
*** query(String sql,ResultSetHandler rsh, Object... values); //执行查询语句
ResultSetHandler: //是一个接口, 表示对 结果集的处理方式, 传入的参数不同, 返回值也不同.
int update(String sql,Object... values); //执行更新语句 C: 操作结果集. //可变参数的底层其实是一个: 数组.
ResultSetHandler接口的子类:
ArrayHandler 将结果集第一行转成对象数组 Object[]
ArrayListHandler List<Object[]>
将结果集中的每一行数据都转成一个对象数组,再将转成的多个对象数组存放到List中 BeanHandler 将结果集第一行数据封装到一个对应的业务类实例中
// new BeanHandler<业务类的类型>(业务类的字节码文件对象);
// new BeanHandler<Ledger>(Ledger.class);
BeanListHandler
将结果集中的每一行数据都封装到一个对应的业务类实例中,再将多个业务类实例对象存放到List里。
// new BeanListHandler<业务类的类型>(业务类的字节码文件对象);
// new BeanListHandler<Ledger>(Ledger.class);
MapHandler 将结果集中的第一行数据封装到一个Map中,key是列名 String ,value是对应的值 Obje
MapListHandler 将结果集中的每一行数据都封装到一个Map里,然后再将多个Map存放到List ColumnListHandler 将结果集中的指定列的数据存储到List集合
//new ColumnListHandler<该列的类型_写的是引用类型>(列名);
//new ColumnListHandler<Double>("money");
ScalarHandler 进行单值查询,如:select count(*) from //一行一列
//new ScalarHandler<该列的类型_写的是引用类型>(列名);
//new ScalarHandler<Long>("counts"); 求满足条件的数据共有多少行
KeyedHandler 将结果集中的每一行数据都封装为一个Map(Map<String,Object>),
再将这些Map再存到一个Map里,其key为KeyedHandler指定的列,
如果没有指定则使用第一个查询的字段。
/*
1 2 3 4
Map <String,Map<String,Object>> map= qr.query(conn, sql, new KeyedHandler<String>("lid")); 1:代表的是 传入的指定的列名(要求不能重复,一般传的是主键)
2:代表的是 数据库表中的每一行数据(列名做键,具体的数据做值)
3:代表的是 传入的指定的列的 数据类型
4:代表的是 传入的指定的列 */

使用DbUtils执行更新操作:

/**
* 使用DbUtils执行更新操作
* 使用之前需要导入jar包
*/
public class Test {
public static void main(String[] args) {
//获取可执行sql语句的对象
//这里构造函数里需要传一个连接池对象 我们使用之前封装的C3P0简单工具类获取一个连接池对象
QueryRunner qr = new QueryRunner(C3P0SimpleUtils.getDataSource());
//执行sql语句 获取返回结果
String sql = "UPDATE users SET psw = ? WHERE uid = ?";
try {
Object[] obj = {null, "亚索", "hasagei"};
int num = qr.update(sql, obj);
System.out.println(num > 0 ? "添加成功" : "添加失败");
} catch (SQLException e) {
e.printStackTrace();
}
//不用再close了 因为DbUtils帮我们做了
}
}

使用DbUtils执行查询操作:

/**
* DbUtils执行查询操作
*/
public class Test {
public static void main(String[] args) { } /**
* ArrayHandler 把查询的第一条数据封装成Object类型的对象返回
*/
private static void method1() {
//获取执行sql的对象
QueryRunner qr = new QueryRunner(C3P0SimpleUtils.getDataSource());
//执行sql
String sql = "SELECT * FROM users WHERE uid = ?";
try {
Object[] obj = qr.query(sql, new ArrayHandler(), );
System.out.println(Arrays.toString(obj));
} catch (SQLException e) {
e.printStackTrace();
}
} /**
* ArrayListHandler 把查询的每一条数据封装成Object类型 放到List<Object>中 返回
*/
public static void method2() {
//获取执行sql的对象
QueryRunner qr = new QueryRunner(C3P0SimpleUtils.getDataSource());
//执行sql
String sql = "SELECT * FROM users";
try {
List<Object[]> list = qr.query(sql, new ArrayListHandler());
for (Object[] obj : list) {
System.out.println(Arrays.toString(obj));
}
} catch (SQLException e) {
e.printStackTrace();
}
} /**
* MapHandler 把第一条数据封装成: Map<String,Object>, 键:数据表的列名做键 值:该列的数据做值
*/
public static void method3() {
QueryRunner qr = new QueryRunner(C3P0SimpleUtils.getDataSource());
String sql = "SELECT * FROM users WHERE uid = ?";
try {
Map<String, Object> map = qr.query(sql, new MapHandler(), );
System.out.println(map);
} catch (SQLException e) {
e.printStackTrace();
}
} /**
* MapListHandler 把每一条数据封装成Map<String,Object>, 整体放入: List<Map<String,Object>>
*/
public static void method4() {
QueryRunner qr = new QueryRunner(C3P0SimpleUtils.getDataSource());
String sql = "SELECT * FROM users";
try {
List<Map<String, Object>> list = qr.query(sql, new MapListHandler());
for (Map<String, Object> map : list) {
System.out.println(map);
}
} catch (SQLException e) {
e.printStackTrace();
}
} /**
* BeanHandler 把第一条数据封装成 JavaBean对象返回
*/
public static void method5() {
QueryRunner qr = new QueryRunner(C3P0SimpleUtils.getDataSource());
String sql = "SELECT * FROM users WHERE uid = ?";
try {
Users user = qr.query(sql, new BeanHandler<Users>(Users.class), );
System.out.println(user);
} catch (SQLException e) {
e.printStackTrace();
}
} /**
* BeanListHandler 把每一条数据封装成JavaBean 放到List集合中返回
*/
public static void method6() {
QueryRunner qr = new QueryRunner(C3P0SimpleUtils.getDataSource());
String sql = "SELECT * FROM users";
try {
List<Users> list = qr.query(sql, new BeanListHandler<Users>(Users.class));
for (Users user : list) {
System.out.println(user);
}
} catch (SQLException e) {
e.printStackTrace();
}
} /**
* ColumnListHandler 根据查询的结果集 把其中一列放到List集合中返回
*/
public static void method7() {
QueryRunner qr = new QueryRunner(C3P0SimpleUtils.getDataSource());
String sql = "SELECT * FROM users";
try {
List<Object> list = qr.query(sql, new ColumnListHandler("uname"));
for (Object obj : list) {
System.out.println(obj);
}
} catch (SQLException e) {
e.printStackTrace();
}
} /**
* ScalarHandler 把查询结果的第一行第一列的数据封装成Object返回
*/
public static void method8() {
QueryRunner qr = new QueryRunner(C3P0SimpleUtils.getDataSource());
String sql = "SELECT COUNT(1) FROM users WHERE uid BETWEEN ? AND ?";
try {
Object count = qr.query(sql, new ScalarHandler(), , );
System.out.println(count);
} catch (SQLException e) {
e.printStackTrace();
}
} /**
* 把每一条数据封装成Map<String,Object>, 整体放入: Map<指定的列,Map<String,Object>>
*/
public static void method9() {
QueryRunner qr = new QueryRunner(C3P0SimpleUtils.getDataSource());
String sql = "SELECT * FROM users";
try {
Map<Object, Map<String, Object>> maps = qr.query(sql, new KeyedHandler("uname"));
for (Object key : maps.keySet()) {
System.out.println(key + "--" + maps.get(key));
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}

java基础之JDBC九:DbUtils的简介及使用的更多相关文章

  1. java基础(29):JDBC、DBUtils

    1. JDBC 1.1 JDBC概述 JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问 ...

  2. java基础(11) -JDBC

    java基础(11) -JDBC jdbc 1.装载驱动 载入跟数据库建立连接的驱动 /* sql server: String className ="com.microsoft.sqls ...

  3. java基础解析系列(九)---String不可变性分析

    java基础解析系列(九)---String不可变性分析 目录 java基础解析系列(一)---String.StringBuffer.StringBuilder java基础解析系列(二)---In ...

  4. Java基础-正则表达式(Regular Expression)语法规则简介

    Java基础-正则表达式(Regular Expression)语法规则简介 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.正则表达式的概念 正则表达式(Regular Exp ...

  5. Java基础-StringBuffer类与StringBuilder类简介

    Java基础-StringBuffer类与StringBuilder类简介 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.StringBuffer类 在学习过String类之后 ...

  6. java基础之JDBC六:DBCP 数据库连接池简介

    我们之前写的代码中的数据库连接每次都是自己创建,用完以后自己close()销毁的,这样是很耗费资源的,所以我们引入DBCP DBCP简介 概述: Data Base Connection Pool, ...

  7. 【Java基础】JDBC简明教程

    目录 1. 常用类 2. JDBC编程步骤 3. 事务处理 4. 数据库连接池 5. JDBC列子代码 6. 使用Apache的JDBC工具类 虽然在平时的开发过程中我们不会直接使JDBC的API来操 ...

  8. java基础之JDBC一:概述及步骤详解

    1. JDBC的简介 概述: 就是Java用来操作不同数据库(DBMS)的类库(技术), 本质就是一些类和接口. /* 类: DriverManager 接口: Driver, Connection, ...

  9. Java基础93 JDBC连接MySQL数据库

    本文知识点(目录): 1.什么是jdbc     2.jdbc接口的核心API     3.使用JDBC技术连接MySQL数据库的方法    4.使用Statement执行sql语句(DDL.DML. ...

随机推荐

  1. windows获取屏幕显示比例 读取注册表法

    static int GetDesktopScale() { ; HINSTANCE hUser32 = LoadLibrary(L"user32.dll"); if (hUser ...

  2. Django之 路由系统

    Django的路由系统 URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表:你就是以这种方式告诉Django,对于这个URL调用这 ...

  3. 关于15桥梁课程1&2的笔记以及待做事项的梳理

    1.指针所占用的空间是固定的 2.void *malloc(sizeof(int)); (这玩意耗时间,老师说通过内存池解决) free(p);free(p);   两次free()报错,正确的做法: ...

  4. [转载] ffmpeg函数介绍

    本文对在使用ffmpeg进行音视频编解码时使用到的一些函数做一个简单介绍,我当前使用的ffmpeg版本为:0.8.5,因为本人发现在不同的版本中,有些函数名称会有点小改动,所以在此有必要说明下ffmp ...

  5. 实体对象,List泛型 转换为DataTable

    /// <summary>        /// 实体对象转换DataTable        /// </summary>        /// <param name ...

  6. [BZOJ]4034: [HAOI2015]树上操作

    [HAOI2015]树上操作 传送门 题目大意:三个操作 1:a,b,c b节点权值+c 2:a,b,c 以b为根的子树节点权值全部+c 3:a,b 查询b到根路径的权值和. 题解:树链剖分 操作1 ...

  7. jQuery火箭图标返回顶部代码

    在网上找来段使用jQuery火箭图标返回顶部代码,感觉比较酷,比较炫,大概样式如下, 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1. ...

  8. vba打开excel文件遍历sheet的名字和指定单元格的值

    今天项目上有个应用,获取指定Excel文件下的所有sheet的名称以及当前sheet中指定单元格的值,并把他们写到固定的sheet中去,看了下,文件比较多,而且每个文件sheet的个数比较多,也不一样 ...

  9. MFC命令消息的路由

    下面,我们以Menu这个程序为例,来看看 菜单命令消息路由的具体过程:当单击某个菜单项时,最先接收到这个菜单命令消息的是框架类.框架类将把接收到的这个消息交给它的子窗口.即视类,由视类首先进行处理.视 ...

  10. MySQL error : Deadlock found when trying to get lock; try restarting transaction

    在使用 MySQL 时,我们有时会遇到这样的报错:“Deadlock found when trying to get lock; try restarting transaction”. 在 14. ...