使用非常简单,首先导入需要的jar包,但是在使用中需要 DataSource或者Connection 这需要自己写Utils类,或者用C3P0或者DBCP获取,如有不解详见上篇博客:
用例如下:
以下构造参数如果没传数据源,那么必须在使用查询、更新等操作时选择传递Connection的方法。
//这里我使用了C3P0数据源。
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
qr.query("SELECT * FROM users WHERE NAME=? AND pwd=?;", new BeanHandler<User>(User.class), name, pwd);
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
qr.query("SELECT * FROM books;", new BeanListHandler<Books>(Books.class));
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
qr.update("INSERT INTO books VALUES(?,?,?,?,?,?)", book.getId(), book.getName(), book.getPrice(), book.getNum(), book.getLb(), book.getContent());
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
qr.query("SELECT * FROM books where id=?;", new BeanHandler<Books>(Books.class), id);
QueryRunner qr = new QueryRunner(C3P0Util.getDataSource());
qr.update("update books set name=?,price=?,num=?,lb=?,content=? where id=?", book.getName(), book.getPrice(), book.getNum(), book.getLb(), book.getContent(), book.getId());
看到这里,是不是觉得用apache的dbutils进行CRUD很简单很方便呢。
下面再介绍一种很实用的工具吧,同属apache公司的BeanUtils。
同上先导入jar包,这里需要使用两个:
commons-beanutils-1.8.3.jar
commons-logging-1.1.1.jar
BeanUtils.setProperty(bean, name, value);其中bean是指你将要设置的对象,name指的是将要设置的属性(写成”属性名”),value(从配置文件中读取到到的字符串值)
BeanUtils。copyProperties(bean, name, value),和上面的方法是完全一样的。使用哪个都可以
ConvertUtils.register(Converter converter , ..),当需要将String数据转换成引用数据类型(自定义数据类型时),需要使用此方法实现转换。
BeanUtils.populate(bean,Map),其中Map中的key必须与目标对象中的属性名相同,否则不能实现拷贝。
BeanUtils.copyProperties(newObject,oldObject),实现对象的拷贝
//需要给一个映射的数据源Map。
Map<String, String[]> map;
//将map里面的数据通过反射,将数据映射到实体类。
BeanUtils.populate(book, map);
//需要注意,实体类中声明的变量需要与map对应。
ConvertUtils.register(Converter converter , ..)方法用例:
//使用日起转换器工具类
ConvertUtils.register(new DateLocaleConverter(), Date.class);
public void test() throws Exception {
Map map = new HashMap();
map.put("name", "xiazdong");
map.put("age", "20");
map.put("birth", "2010-10-10");
ConvertUtils.register(new DateLocaleConverter(), Date.class);
Person p = new Person();
BeanUtils.populate(p, map);
System.out.println(p.getAge());
System.out.println(p.getBirth().toLocaleString());
}
ConvertUtils.register(new Converter() {
//自定义日期类型转换器
@Override
public Object convert(Class type, Object value) { //type:目前需要转换的数据类型 value:目前参数的值
//目标:将字符串转换为日期
if(type != Date.class) return null;
if (value == null || "".equals(value.toString().trim())) {
return null;
}
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy年MM月dd日");
Date date = null;
try {
date = dateFormat.parse((String)value);
} catch (ParseException e) {
throw new RuntimeException(e);
}
return date;
}
}, Date.class); //Date.class表示要转换的成引用类型,Date类型不是基本数据类型,所以需要一个转换器进行相应的转换,同样该功能属于BeanUtils
下面传几个使用案例,实现了登陆、查看列表、修改单个商品、增加单个商品、删除等功能,数据均来自数据库真实数据,非模拟。