使用dbUtil多表查询获取的数据涉及多个对象时的封装

我们使用dbUtil查询数据库时,一般是单表查询,封装数据都是单个对象,可以直接封装,当碰到更复杂的数据,比如从一个sql语句同时查询商品信息和客户信息封装到一个订单的对象中,订单对象中的属性如果是商品的属性,字段可以和查询数据库返回的数据的字段一一对应,那么直接封装没问题,点击查看一般方法但是如果商品对象作为订单的成员变量的话,直接封装时属于商品的属性找不到对应字段导致封装失败,此时可用以下方法:


List> mapList = runner.query(sql, new MapListHandler(), .....);返回一个装有map的集合,有name,id,和商品的price,pname四个字段

//遍历拿出数据

for(Map map : mapList){


//从map中取出name,id 封装到User中

BeanUtils.populate(user, map);


//从map中取出pname,price 封装到Product中


BeanUtils.populate(product, map);


//将product,user封装到Order


order.setProduct(product);


order.setUser(user)


你可能感兴趣的:(工具)