<dependency>
<groupId>commons-dbutils</groupId>
<artifactId>commons-dbutils</artifactId>
<version>1.7</version>
</dependency>

 

package jachs.commons.dbutils.examples;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Properties; import org.apache.commons.dbcp2.BasicDataSource;
import org.apache.commons.dbcp2.BasicDataSourceFactory;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.ResultSetHandler;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.BeanMapHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import org.junit.Before;
import org.junit.Test; import jachs.commons.dbcp.BasicDataSourceDemo; /****
* 文档http://commons.apache.org/proper/commons-dbutils/apidocs/index.html
* 示例http://commons.apache.org/proper/commons-dbutils/examples.html
*
* @author zhanchaohan
*
*/
public class Demo {
private BasicDataSource bds = new BasicDataSource(); @Before
public void init() throws Exception {
Properties properties = new Properties();
properties.load(BasicDataSourceDemo.class.getResourceAsStream("config.properties"));
BasicDataSourceFactory bdsf = new BasicDataSourceFactory();
bds = bdsf.createDataSource(properties);
} @Test
public void insert() throws SQLException {
// QueryRunner run = new QueryRunner();
QueryRunner run = new QueryRunner(bds, true);// 使用的QueryRunner的构造函数。
ScalarHandler scalarHandler = new ScalarHandler();
run.insert("insert into test value('lks',15,'日本')", scalarHandler);
run.insert("insert into test value(?,?,?)", scalarHandler, "zhangsan", 20, "南京");
} @Test
public void delete() throws SQLException {
QueryRunner run = new QueryRunner(bds, true);
// int index=run.execute("delete from test where name=? or name=?", "zhangsan","lks");
int count = run.execute("delete from test where name='zhangsan' or name='lks'");
System.out.println(count);
} @Test
public void update() throws SQLException {
QueryRunner run = new QueryRunner(bds, true);
// int count=run.update("update test set name='lisi' where name='lks'");
int count = run.update("update test set name=? where name=?", "lisi", "lks");
System.out.println(count);
} /****
* 查询 1. ResultSetHandler 的作用: QueryRunner 的 query 方法的返回值最终取决于 query 方法的
* ResultHandler 参数的 hanlde 方法的返回值。 2. BeanListHandler: 把结果集转为一个 Bean 的 List,
* 并返回.。Bean的类型在创建 BeanListHanlder对象时以 Class对象的方式传入,可以适应列的别名来映射 JavaBean 的属性 名:
* String sql = "SELECT id, name customerName, email, birth " + "FROM customers
* WHERE id = ?"; BeanListHandler(Class<T> type)。 3. BeanHandler: 把结果集转为一个
* Bean,并返回.。Bean的类型在创建BeanHandler 对象时以 Class 对象的方式传入 BeanHandler(Class<T>
* type)。 4. MapHandler: 把结果集转为一个 Map 对象, 并返回。若结果集中有多条记录, 仅返回
* 第一条记录对应的Map对象.。Map的键: 列名(而非列的别名), 值: 列的值。 5. MapListHandler: 把结果集转为一个 Map
* 对象的集合, 并返回.。Map的键: 列名(而非列的别名), 值: 列的值。 6. ScalarHandler:
* 可以返回指定列的一个值或返回一个统计函数的值,比如count(1)。
*
* @throws SQLException
*/
@Test
public void query() throws SQLException {
ResultSetHandler<List<List<Object>>> rsh = new ResultSetHandler<List<List<Object>>>() {
@Override
public List<List<Object>> handle(ResultSet rs) throws SQLException {
List<List<Object>> data = new ArrayList<List<Object>>();
while (rs.next()) {
List<Object> obj = new ArrayList<Object>();
obj.add(rs.getObject(1));
obj.add(rs.getObject(2));
obj.add(rs.getObject(3));
data.add(obj);
}
return data;
}
};
QueryRunner run = new QueryRunner(bds, true);
String sql = "select * from test where name='lisi' or name='zhangsan' or name='张三'";
List<List<Object>> ls = run.query(sql, rsh);
for (List<Object> list : ls) {
System.out.println(list.get(0) + "\t" + list.get(1) + "\t" + list.get(2));
}
} @Test
public void query1() throws SQLException {
// QueryRunner run = new QueryRunner(bds, true);
// BeanHandler bh = new BeanHandler<test>(test.class);
// String sql = "select * from test where name=?";
// test tsArr = run.query(sql, "lisi", bh);
// System.out.println(tsArr.getName() + "\t" + tsArr.getAge() + "\t" + tsArr.getArea()); // 提供了一个自定义接口RowProcessor,要自己实现
// MyRowProcessor mrp = new MyRowProcessor();
// 多条
QueryRunner run = new QueryRunner(bds, true);
ResultSetHandler<Map<String, test>> h = new BeanMapHandler<String, test>(test.class, "name");
String sql = "select * from test where name=? or name=? or name=?";
Map<String, test> tsArr = run.query(sql, new String[] { "lisi", "zhangsan", "张三" }, h);
for (String key : tsArr.keySet()) {
System.out.println(key);
System.out.println(tsArr.get(key).getName()+"\t"+tsArr.get(key).getAge()+"\t"+tsArr.get(key).getAge());
System.out.println("-----------------------------------------");
}
}
}

  

Commons-DbUtils的更多相关文章

  1. 高性能jdbc封装工具 Apache Commons DbUtils 1.6(转载)

    转载自原文地址:http://gao-xianglong.iteye.com/blog/2166444 前言 关于Apache的DbUtils中间件或许了解的人并不多,大部分开发人员在生成环境中更多的 ...

  2. Apache Commons DbUtils 快速上手

    原文出处:http://lavasoft.blog.51cto.com/62575/222771 Hibernate太复杂,iBatis不好用,JDBC代码太垃圾,DBUtils在简单与优美之间取得了 ...

  3. 写一个ORM框架的第一步(Apache Commons DbUtils)

    新一次的内部提升开始了,如果您想写一个框架从Apache Commons DbUtils开始学习是一种不错的选择,我们先学习应用这个小“框架”再把源代码理解,然后写一个属于自己的ORM框架不是梦. 一 ...

  4. java JDBC (七) org.apache.commons.dbutils 查询

    package cn.sasa.demo1; import java.sql.Connection; import java.sql.SQLException; import java.util.Li ...

  5. java JDBC (六) org.apache.commons.dbutils 增删改

    dbutils是apache封装了JDBC的工具类,比mysql-connector更方便些 下载地址:http://commons.apache.org/proper/commons-dbutils ...

  6. Java连接数据库 #04# Apache Commons DbUtils

    索引 通过一个简单的调用看整体结构 Examples 修改JAVA连接数据库#03#中的代码 DbUtils并非是什么ORM框架,只是对原始的JDBC进行了一些封装,以便我们少写一些重复代码.就“用” ...

  7. 《笔者带你剖析Apache Commons DbUtils 1.6》(转)

    前言 关于Apache的DbUtils中间件或许了解的人并不多,大部分开发人员在生成环境中更 多的是依靠Hibernate.Ibatis.Spring JDBC.JPA等大厂提供的持久层技术解决方案, ...

  8. commons.dbutils 的使用列子

    c0p3的导入请参考前文 https://www.cnblogs.com/appium/p/10183016.html JdbcUtils: package cn.itcast.jdbc; impor ...

  9. java.lang.ClassNotFoundException: org.apache.commons.dbutils.QueryRunner

    七月 28, 2017 11:06:33 下午 org.apache.catalina.core.StandardWrapperValve invoke严重: Servlet.service() fo ...

  10. 模拟apache commons dbutils 实现自己的BeanListHandler(回调应用)

    首先dbcp相关的jar包和MySQL的驱动包导入到项目中. dbcp.properties配置文件如下,并放到项目根目录下. driverClassName=com.mysql.jdbc.Drive ...

随机推荐

  1. qml demo分析(clocks-时钟)

    一.效果展示 效果如图1所示,时钟列表支持鼠标左右拖动,带有黑色背景的是晚上时钟,无黑色背景的是白天时钟 二.源码分析 1.main.cpp文件中只包含了一个宏,该宏的具体解释请看qml 示例中的关键 ...

  2. 使用redis有序集合sorted set设计高效查询ip所在地

    1.将纯真版ip数据  xxx.data 导入至 redis(整个过程只花费了几秒) 引入nuget包 CSRedisCore,使用方法见:https://github.com/2881099/csr ...

  3. Scrum Mastery:产品开发中如何优化产品价值?

    您是否在开发对组织来说有价值的产品?如何判断产品是否有价值? 如果没有经常提出这两个问题,那么您可能忽略了产品价值方面的问题. 产品是目前工作所要达成的目的,是组建团队的原因.产品也是你选择Scrum ...

  4. Java——容器类库框架浅析

    前言 通常,我们总是在程序运行过程中才获得一些条件去创建对象,这些动态创建的对象就需要使用一些方式去保存.我们可以使用数组去存储,但是需要注意数组的尺寸一旦定义便不可修改,而我们并不知道程序在运行过程 ...

  5. [SpringBoot guides系列翻译]调度任务

    原文 调度任务 用spring实现一个任务调度. 你将做的 你将做一个应用每5秒钟打印当前时间,用@Scheduled注解. 你需要啥 15分钟 文本编辑器或者IDE JDK1.8+ Gradle4+ ...

  6. 【带着canvas去流浪(7)】绘制水球图

    目录 一. 任务说明 二. 重点提示 三. 示例代码 四. 文字淹水效果的实现 五. 关于canvas抗锯齿 六. 小结 示例代码托管在:http://www.github.com/dashnowor ...

  7. java爬虫系列第二讲-爬取最新动作电影《海王》迅雷下载地址

    1. 目标 使用webmagic爬取动作电影列表信息 爬取电影<海王>详细信息[电影名称.电影迅雷下载地址列表] 2. 爬取最新动作片列表 获取电影列表页面数据来源地址 访问http:// ...

  8. Django之模板系统

    变量的使用: def test(request): num=1 s='hello' li=[1,2,['a','b']] dic={'name':'w','age':1} se={1,2,3} tup ...

  9. 网页三剑客:HTML+CSS+JavaScript 之JavaScript

    JavaScript 简介 JavaScript 是互联网上最流行的脚本语言,这门语言可用于 HTML 和 web,更可广泛用于服务器.PC.笔记本电脑.平板电脑和智能手机等设备. JavaScrip ...

  10. 2D射影几何和变换

    阅读<计算机视觉中的多视图集合> 2D射影几何和变换 2D射影平面 本章的关键是理解线和点的对偶性.从射影平面模型出发,IP^2^内的点(a, b ,c)由IP^3^空间中一条过原点的射线 ...