spring mvc +jdbctemplate 返回多表查询List<Bean>

发现 hibernate做多表查询 是忒麻烦了
Spring JDBC提供了一个BeanPropertyRowMapper的实现,能够自动将数据库表中读出的字段与Domain对象的属性进行映射

果断用 jdbctemplate啊 下面 说下方法
首先 在dao里 注入下
@Autowired
public JdbcTemplate jdbcTemplate;

然后在springappplication.xml里 配置下
<!-- jdbc注入 -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource">
<ref bean="dataSource" />
</property>
</bean>

然后建立一个符合自己业务的bean

然后写dao方法
	public List<GoodsListBean> findGoodsListBean(String goodsnum, Integer vmid,
Integer omid, String rusjstart, String rusjend) throws Exception {
// if (userid == null) {
// return new ArrayList<PusMenu>();
// }
StringBuilder sbstr = new StringBuilder(
"SELECT g.*,u.name acceptancename,c.name companyname,vm.name vmname"
+ " ,om.name omname,cc.name contactsname FROM goods g,pus_sys_user u,companyinfors c "
+ " ,variety_management vm,origin_management om ,companycontacts cc WHERE g.acceptanceid=u.id"
+ " AND g.companyid=c.id AND g.vmid=vm.id AND g.omid=om.id "
+ " AND g.contactsid=cc.id AND g.state=1");

List<GoodsListBean> list = jdbcTemplate.query(sbstr.toString(), new BeanPropertyRowMapper(GoodsListBean.class));
return list;
}


最后把这个list直接丢到easyui的rows里就好了

List<GoodsListBean> listg=new ArrayList<GoodsListBean>();
//List<GoodsListBean> listgend=new ArrayList<GoodsListBean>();
try {
listg=goodsDao.findGoodsListBean(goodsnum, vmid, omid,rusjstart, rusjend);
} catch (Exception e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
logger.error("货物查询异常", e1);
listg=new ArrayList<GoodsListBean>();
}
mapjson.put(
"rows",
listg);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值