QueryRunner类 的應用,以及ResultSetHandler 接口的实现类
1 .该接口用于处理 java.sql.ResultSet,将数据按要求转换为另一种形式。
ResultSetHandler 接口提供了一个单独的方法:Object handle (java.sql.ResultSet .rs)。
2.ResultSetHandler 接口的实现类
|
ArrayHandler:把结果集中的第一行数据转成对象数组。 |
3.示例代碼如下:
1.首先定義一實體類
package com.beiwo.day05.entity; import java.io.Serializable;
import java.sql.Date; public class Person implements Serializable{ /**
*
*/
private static final long serialVersionUID = 1L; private int id; private String name; private String password; private String email; private Date birthday; public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} public String getEmail() {
return email;
} public void setEmail(String email) {
this.email = email;
} public Date getBirthday() {
return birthday;
} public void setBirthday(Date birthday) {
this.birthday = birthday;
} public static long getSerialversionuid() {
return serialVersionUID;
} @Override
public String toString() {
return "Person [id=" + id + ", name=" + name + ", password=" + password
+ ", email=" + email + ", birthday=" + birthday + ", getId()="
+ getId() + ", getName()=" + getName() + ", getPassword()="
+ getPassword() + ", getEmail()=" + getEmail()
+ ", getBirthday()=" + getBirthday() + ", getClass()="
+ getClass() + ", hashCode()=" + hashCode() + ", toString()="
+ super.toString() + "]";
} }
測試查詢
package com.beiwo.day05.test; import java.sql.SQLException;
import java.util.List;
import java.util.Map; import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ArrayHandler;
import org.apache.commons.dbutils.handlers.ArrayListHandler;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ColumnListHandler;
import org.apache.commons.dbutils.handlers.MapHandler;
import org.apache.commons.dbutils.handlers.MapListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import org.junit.Test; import com.beiwo.day05.entity.Person;
import com.beiwo.day05.util.C3P0Util; public class TestDBUtils { @Test //把结果集中的每一行数据都转成一个数组,再存放到List中。 public void testArrayListHandler() throws SQLException{
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
String sql = "SELECT * FROM person"; List<Object[]> list = qr.query(sql, new ArrayListHandler()); for (Object[] objects : list) {
for (Object object : objects) {
System.out.println(object);
}
System.out.println("-----------------------------");
}
} @Test //把结果集中的第一行数据转成对象数组。 public void testArrayHandler() throws SQLException{
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
String sql = "SELECT * FROM person"; Object[] object = qr.query(sql, new ArrayHandler());
for(Object object1 : object){
System.out.println(object1);
} } // @Test 将结果集中某一列的数据存放到List中。
public void testColumnListHandler() throws SQLException{
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
String sql = "SELECT name,password,email,birthday FROM person"; List<Object> persons = qr.query(sql, new ColumnListHandler(2));
for(Object object : persons){
System.out.println(object);
} } @Test //将结果集中的第一行数据封装到一个Map里,key是列名,value就是对应的值。 public void testMapHandler() throws SQLException{
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
String sql = "SELECT * FROM person WHERE id=?"; Map<String, Object> map= qr.query(sql, new MapHandler(),1);
for (Map.Entry<String, Object> m:map.entrySet()) {
System.out.println(m.getKey() + "\t" + m.getValue());
} } @Test //将结果集中的每一行数据都封装到一个Map里,然后再存放到List public void testMapListHandler() throws SQLException{
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
String sql = "SELECT * FROM person "; List<Map<String, Object>> list = qr.query(sql, new MapListHandler());
for (Map<String, Object> map : list) {
for (Map.Entry<String, Object> m : map.entrySet()) {
System.out.println(m.getKey() + "\t" + m.getValue());
}
System.out.println("--------------------------------------------");
} } @Test //查询数据库中信息的总条数
public void testScalarHandler() throws SQLException{
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
String sql = "SELECT COUNT(*) FROM person "; Long l = (Long)qr.query(sql, new ScalarHandler(1));
System.out.println(l); } @Test //将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里。 public void testBeanListHandler() throws SQLException{
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
String sql = "SELECT * FROM person "; List<Person> list = qr.query(sql, new BeanListHandler<Person>(Person.class));
System.out.println(list);
} @Test //将结果集中的第一行数据封装到一个对应的JavaBean实例中。
public void testBeanHandler() throws SQLException{
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
String sql = "SELECT * FROM person WHERE id=?"; Person person = qr.query(sql, new BeanHandler<Person>(Person.class),1);
System.out.println(person);
}
}
測試增刪改
package com.beiwo.day05.test; import java.sql.SQLException;
import java.util.Date; import org.apache.commons.dbutils.QueryRunner;
import org.junit.Test; import com.beiwo.day05.util.C3P0Util; public class TestUpDate { @Test
public void testInsert() throws SQLException{
QueryRunner qRunner = new QueryRunner(C3P0Util.getDataSource());
String sql = "INSERT INTO person(name,password,email,birthday)VALUES(?,?,?,?)";
qRunner.update(sql, "ccc","789","789@qq.com",new Date());
} @Test
public void testUpDate1() throws SQLException{
QueryRunner qRunner = new QueryRunner(C3P0Util.getDataSource());
String sql = "UPDATE person SET name='www' WHERE id=2";
qRunner.update(sql);
} @Test
public void testUpDate2() throws SQLException{
QueryRunner qRunner = new QueryRunner(C3P0Util.getDataSource());
String sql = "DELETE FROM person WHERE id=6";
qRunner.update(sql);
} }
QueryRunner类 的應用,以及ResultSetHandler 接口的实现类的更多相关文章
- JAVA中所有与集合有关的实现类都是这六个接口的实现类
JAVA中所有与集合有关的实现类都是这六个接口的实现类. Collection接口:集合中每一个元素为一个对象,这个接口将这些对象组织在一起,形成一维结构. List接口代表按照元素一定的相关顺序来组 ...
- 使用DbUtils实现增删改查——ResultSetHandler 接口的实现类
在上一篇文章中<使用DbUtils实现增删改查>,发现运行runner.query()这行代码时.须要自己去处理查询到的结果集,比較麻烦.这行代码的原型是: public Object q ...
- pache—DBUtils框架简介、DbUtils类、QueryRunner类 、ResultSetHandler接口
Apache—DBUtils框架简介.DbUtils类.QueryRunner类 .ResultSetHandler接口 commons-dbutils 是 Apache 组织提供的一个开源 JDBC ...
- Apache——DBUtils框架ResultSetHandler接口使用
参考链接:http://i.cnblogs.com/EditPosts.aspx?opt=1 简介 commons-dbutils 是 Apache 组织提供的一个开源 JDBC工具类库,它是对JDB ...
- DBUtils框架ResultSetHandler接口学习
今儿在学习spring框架的时候,让我想起来之前做项目时一直搁置的一个问题,就是DBUtils框架的做数据库操作的使用,当时制作项目的时候就是通过实例打了一遍,由于时间原因也并没有仔细去了解这一方面. ...
- 【无私分享:ASP.NET CORE 项目实战(第二章)】添加EF上下文对象,添加接口、实现类以及无处不在的依赖注入(DI)
目录索引 [无私分享:ASP.NET CORE 项目实战]目录索引 简介 上一章,我们介绍了安装和新建控制器.视图,这一章我们来创建个数据模型,并且添加接口和实现类. 添加EF上下文对象 按照我们以前 ...
- spring的依赖注入,为什么用接口的实现类而不是父类的继承类?
@Resource private EmployeeService employeeService; public void setEmployeeService(EmployeeService em ...
- Java基础-多线程编程-1.随便选择两个城市作为预选旅游目标。实现两个独立的线程分别显示10次城市名,每次显示后休眠一段随机时间(1000ms以内),哪个先显示完毕,就决定去哪个城市。分别用Runnable接口和Thread类实现。
1.随便选择两个城市作为预选旅游目标.实现两个独立的线程分别显示10次城市名,每次显示后休眠一段随机时间(1000ms以内),哪个先显示完毕,就决定去哪个城市.分别用Runnable接口和Thread ...
- Hibernate的实体类为什么要实现Serializable序列化接口?
Hibernate的实体类中为什么要继承Serializable? hibernate有二级缓存,缓存会将对象写进硬盘,就必须序列化,以及兼容对象在网络中的传输 等等. java中常见的几个类(如 ...
随机推荐
- 商业智能SAAS走向中小企业
20多年前,Gartner提出了商业智能的概念,并将其定义为“一类由数据仓库.查询报表.数据分析.数据挖掘等部分组成的,以帮助企业决策的技术及应用”.从技术上讲,商业智能是数据仓库.OLAP和数据挖掘 ...
- DVWA安装,ALMP环境搭建以及php版本转换
前言 本文记录DVWA(Damn Vulberability Web App)在虚拟机中安装配置,包括ALMP环境的搭建和php版本的转换. 目录 2. ALMP环境搭建 3. php版本切换 一. ...
- iOS之ShareSDK实现分享、第三方登录等功能
(1)官方下载ShareSDK iOS 2.8.8,地址:http://sharesdk.cn/ (2)根据实际情况,引入相关的库,参考官方文档. (3)在项目的AppDelegate中一般情况下有三 ...
- iOS通知中心升级 -可设置按优先级执行block
简单介绍下,这是需求驱动中发现iOS的NotificationCenter有很多功能无法实现,于是对其进行了一层包装.相当于手动管理观察者栈和监听者期望执行的事件,因此可以为其添加了很多新增的功能,将 ...
- iOS多线程之5.GCD的基本使用
上一篇文章我对GCD的几个基本概念做了介绍,但是大家看完了可能觉得对理解GCD并没有什么卵用.其实会用GCD其实很简单,只要记住两条就可以了. 1. 主队列里的任务必须在异步函数中执行. 主队 ...
- 推荐几个精致的web UI框架
1.Aliceui Aliceui是支付宝的样式解决方案,是一套精选的基于 spm 生态圈的样式模块集合,是 Arale 的子集,也是一套模块化的样式命名和组织规范,是写 CSS 的更好方式. git ...
- Meet Sccot Guthrie in Shanghai
9月16日,有幸和其他9位MVP一起在上海和微软全球副总裁Sccot Guthrie.开发工具部门Somasegar.微软中国申元庆见面,聊关于Azure和开发方面的话题.同时,由于本人目前对物联网( ...
- Database 'xxxx' is being recovered. Waiting until recovery is finished.
巡检发现一个SQL SERVER Express 2005数据库备份时出现下面错误: Database 'xxxx' is being recovered. Waiting until recover ...
- [AlwaysOn Availability Groups]CLUSTER.LOG(AG)
CLUSTER.LOG(AG) 作为故障转移资源,在SQL Server和windows故障转移集群服务的资源DLL(hadrres.dll)之间有额外的内部交流,DLL无法被SQL Server监控 ...
- MongoDB学习笔记~Mongo集群和副本集
回到目录 一些概念 对于Mongo在数据容灾上,推荐的模式是使用副本集模式,它有一个对外的主服务器Primary,还有N个副本服务器Secondary(N>=1,当N=1时,需要有一台仲裁服务器 ...