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

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

orderitem表:

【javaweb:多表查询】多表查询的一个例子_第1张图片

product表:


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

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

而且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> 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> query = qr.query(sql, new MapListHandler(), oid);
		//查询结果的每一行构成一个Map集合,Map的key为查询的字段名(即列名)
		return query;
	}

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

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

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

【javaweb:多表查询】多表查询的一个例子_第2张图片

4、三表查询举例


你可能感兴趣的:(JavaWeb)