【javaweb:多表查询】多表查询的一个例子

1、首先有两个表,一个orderitem表(从表),一个product表(主表)如下图所示

orderitem表:


product表:


2、如果要查询两个表中指定列的信息,比如orderitem表中的count,subtotal,product表中的pname,pimage等

那么就涉及到多表查询,而且对查询的结果封装的时候要用:Map<String, Object>

而且sql语言要注意他的书写格式:请看下面,我查询的是对应orderItem表中oid为某个值下的信息,这个oid是第三个表的主键

select o.count,o.subtotal,p.pimage,p.pname,p.shop_price  from orderitem o,product p where o.pid=p.pid and o.oid=?

可以看到,o和p为我为表的简化命名,o.pid=p.pid这个很关键,代表了他们的主从表对应关系或者查询的基本要求,后面的

o.oid为在之前的主从表关系基础上,你想要设置的要求。

完整的dao层查询代码如下:

public List<Map<String,Object>> findOrderNeedInfo(String oid) throws SQLException {
		//使用多表查询,获取你想要的信息
		QueryRunner qr=new QueryRunner(DataSourceUtils.getDataSource());
		String sql="select o.count,o.subtotal,p.pimage,p.pname,p.shop_price  from orderitem o,product p where o.pid=p.pid and o.oid=?";
		List<Map<String, Object>> query = qr.query(sql, new MapListHandler(), oid);
		//查询结果的每一行构成一个Map集合,Map的key为查询的字段名(即列名)
		return query;
	}

3、DBUtils对数据库中的数据封装,常有以下几种,我们会经常用到,需熟记。

封装的原则:根据列名和实体中的变量名,相一致的,就把数据库中的数据封入实体中,不一致的就不封入。

我们常用的另外一个工具类:BeanUtils.populate(bean,properties)也是同样的原则。


4、三表查询举例


  • 7
    点赞
  • 43
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值