JAVA 入门学习之路-apache-dbutils-BeanUtils使用详解。

使用非常简单,首先导入需要的jar包,但是在使用中需要 DataSource或者Connection 这需要自己写Utils类,或者用C3P0或者DBCP获取,如有不解详见上篇博客:

JAVA 入门学习之路-数据源/连接池-DBCP和C3P0

用例如下:

以下构造参数如果没传数据源,那么必须在使用查询、更新等操作时选择传递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),实现对象的拷贝
//需要给一个映射的数据源MapMap<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

下面传几个使用案例,实现了登陆、查看列表、修改单个商品、增加单个商品、删除等功能,数据均来自数据库真实数据,非模拟。

登陆

登陆成功

数据列表

修改数据

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值