【springmvc+mybatis项目实战】杰信商贸-22.合同货物附件生产厂家mapper关联

我们上一次完成了合同的总金额的计算,我们这次继续完成一个新的更复杂,但是更有学习意义的业务---购销合同查看

要求:查看合同的主信息,查看合同下的货物信息,还要查看附件信息,货物和附件的信息要显示出它们的关联关系。

(注:一个合同下有多个货物,每个货物又有每个货物自己的附件)

利用面对对象的关联关系来实现上面的需求非常简单。

我们之前都是使用的外键进行的关联,这里我们将外键改为实实在在的一个对象,到时候通过对象属性来取下一级的数据,假设之前我们表中有一个货物的外键private String contract_product_id,这个时候我们可以改为一个货物对象:

private ContractProduct cp;

这样我们取联合数据的时候就比较方便了。

首先我们先给合同Contract来创建一个VO对象,用于封装从购销合同中取出的货物的信息:

package cn.hpu.jk.vo;

import java.util.List;

import cn.hpu.jk.domain.ContractProduct;

public class ContractVO {
	private String id;

	private List<ContractProduct> contractProducts;//货物的集合

	private String offeror;//收购方
	private String contractNo;//合同编号

	private String cpnum;
	private String extnum;

	private java.util.Date signingDate;//签单日期
	private String inputBy;//制单人
	private String checkBy;//审单人
	private String inspector;//验货员
	private Double totalAmount;//总金额
	private Integer importNum;//重要程度
	private String crequest;//要求
	private String customName;
	private java.util.Date deliveryPeriod;//交货期限
	private java.util.Date shipTime;//船期
	private String tradeTerms;//贸易条款
	private String remark;//说明
	private String printStyle;//打印版式
	private Integer oldState;//归档前状态
	private Integer state;//状态
	private Integer outState;//走货状态
	private String createBy;
	private String creatDept;
	private java.util.Date creatTime;

	//...get和set方法省略
}

然后给货物ContractProduct配一个VO对象,将外键全部换成实体类:

package cn.hpu.jk.vo;

import java.util.List;

import cn.hpu.jk.domain.Contract;
import cn.hpu.jk.domain.ExtCproduct;
import cn.hpu.jk.domain.Factory;

public class ContractProductVO {
	private String id;

	private Contract contract;//将复杂的关联关系变成单表操作
	private List<ExtCproduct> extCproducts;//和附件一对多
	private Factory factory;//和生产厂家多对一

	private String factoryName;
	private String productNo;
	private String productImage;
	private String productDesc;//货物描述
	private Integer cnumber;//数量
	private Integer outNumber;//出货数量
	private String loadingRate;//装率
	private String boxNum;//箱数
	private String packingUnit;//包装单位
	private Double price;//单价
	private Double amount;//总价
	private Integer finished;//是否出货完毕
	private String exts;//附件
	private Integer orderNo;//排序号

	//...get和set方法省略
}

然后给附件ExtCproduct配一个VO对象,将外键全部换成实体类:

package cn.hpu.jk.vo;

import cn.hpu.jk.domain.ContractProduct;
import cn.hpu.jk.domain.Factory;

public class ExtCproductVO {
	private String id;

	private ContractProduct contractProduct;//多对1
	private Factory factory;//一对多

	private String ctype;
	private String productNo;
	private String productImage;
	private String productDesc;//货物描述
	private Integer cnumber;//数量
	private String packingUnit;//包装单位
	private Double price;//单价
	private Double amount;//总价
	private String productRequest;//要求
	private Integer orderNo;//排序号

	//...get和set方法省略
}

我们的面相对像的方式全配好了,下面就开始陪我们的Mapper

接下来更改购销合同的映射文件ContractMapper.xml的映射结果集ResultMap,让它能够取出一个货物信息之后能把货物信息(货物中包含附件信息)封装到一个实体里:

<resultMap type="cn.hpu.jk.domain.Contract" id="contractRM">
			<id property="id" column="CONTRACT_ID"/>
			<result property="offeror" column="OFFEROR"/>

			<!-- 虚拟字段 -->
			<result property="contractNo" column="CONTRACT_NO"/>
			<result property="cpnum" column="CPNUM"/>

			<result property="extnum" column="EXTNUM"/>
			<result property="signingDate" column="SIGNING_DATE"/>
			<result property="inputBy" column="INPUT_BY"/>
			<result property="checkBy" column="CHECK_BY"/>
			<result property="inspector" column="INSPECTOR"/>
			<result property="totalAmount" column="TOTAL_AMOUNT"/>
			<result property="importNum" column="IMPORT_NUM"/>
			<result property="crequest" column="CREQUEST"/>
			<result property="customName" column="CUSTOM_NAME"/>
			<result property="deliveryPeriod" column="DELIVERY_PERIOD"/>
			<result property="shipTime" column="SHIP_TIME"/>
			<result property="tradeTerms" column="TRADE_TERMS"/>
			<result property="remark" column="REMARK"/>
			<result property="printStyle" column="PRINT_STYLE"/>
			<result property="oldState" column="OLD_STATE"/>
			<result property="state" column="STATE"/>
			<result property="outState" column="OUT_STATE"/>

			<result property="createBy" column="CREATE_BY"/>
			<result property="creatDept" column="CREATE_DEPT"/>
			<result property="creatTime" column="CREATE_TIME"/>
	</resultMap>

	<!-- 合同和货物的关系,一对多。继承自contractRM -->
	<resultMap type="cn.hpu.jk.vo.ContractVO" id="ContractVORM" extends="contractRM">
		<collection property="contractProducts" ofType="cn.hpu.jk.vo.ContractProductVO">
			<id property="id" column="CONTRACT_PRODUCT_ID"/>
			<result property="productNo" column="PRODUCT_NO"/>
			<result property="productImage" column="PRODUCT_IMAGE"/>
			<result property="productDesc" column="PRODUCT_DESC"/>
			<result property="cnumber" column="CNUMBER"/>
			<result property="outNumber" column="OUT_NUMBER"/>
			<result property="loadingRate" column="LOADING_RATE"/>
			<result property="boxNum" column="BOX_NUM"/>
			<result property="packingUnit" column="PACKING_UNIT"/>
			<result property="price" column="PRICE"/>
			<result property="amount" column="AMOUNT"/>
			<result property="finished" column="FINISHED"/>
			<result property="exts" column="EXTS"/>
			<result property="orderNo" column="ORDER_NO"/>

			<!-- 货物附件(一对多) -->
			<collection property="extCproducts" ofType="cn.hpu.jk.vo.ExtCproductVO">
				<id property="id" column="EXT_CPRODUCT_ID"/>
				<result property="ctype" column="CTYPE"/>
				<result property="productNo" column="EXT_PRODUCT_NO"/>
				<result property="productImage" column="EXT_PRODUCT_IMAGE"/>
				<result property="productDesc" column="EXT_PRODUCT_DESC"/>
				<result property="cnumber" column="EXT_CNUMBER"/>
				<result property="packingUnit" column="EXT_PACKING_UNIT"/>
				<result property="price" column="EXT_PRICE"/>
				<result property="amount" column="EXT_AMOUNT"/>
				<result property="productRequest" column="EXT_PRODUCT_REQUEST"/>
				<result property="orderNo" column="EXT_ORDER_NO"/>

				<!-- 货物附件和生产厂家(多对一) -->
				<association property="factory" javaType="cn.hpu.jk.domain.Factory">
					<id property="id" column="EXT_FACTORY_ID"/>
					<result property="fullName" column="EXT_FULL_NAME"/>
					<result property="factoryName" column="EXT_FACTORY_NAME"/>
					<result property="contacts" column="EXT_CONTACTS"/>
					<result property="phone" column="EXT_PHONE"/>
					<!-- 其他字段暂时不需要,所以不做映射 -->
				</association>
			</collection>
		</collection>
	</resultMap>

我们接下来开始写SQL语句,开实现查看合同的主信息,查看合同下的货物信息,还要查看附件信息,货物和附件的信息要显示出它们的关联关系

注意:合同、货物、附件、生产厂家构建复杂多级关联的SQL时原则

1)挑选最小的结果集

2)滚雪球(左连接),逐步往上加内容

3)重复字段,需要起别名(mybatis)

在实际业务中几乎没有内连接的情况,直接就用左连接即可。

(关于左连接、内连接等介绍请查看http://blog.csdn.net/acmman/article/details/48575049)

首先我们将货物和生产厂家拼接起来:

selectcp.CONTRACT_PRODUCT_ID,cp.PRODUCT_NO,cp.PRODUCT_IMAGE,cp.PRODUCT_DESC,cp.CNUMBER,cp.OUT_NUMBER,cp.LOADING_RATE,cp.BOX_NUM,cp.PACKING_UNIT,cp.PRICE,cp.AMOUNT,cp.FINISHED,cp.EXTS,cp.ORDER_NO,
  f.factory_id,f.full_name,f.factory_name,f.contacts,f.phone
from
(select
CONTRACT_PRODUCT_ID,FACTORY_ID,
PRODUCT_NO,PRODUCT_IMAGE,PRODUCT_DESC,CNUMBER,OUT_NUMBER,LOADING_RATE,BOX_NUM,PACKING_UNIT,PRICE,AMOUNT,FINISHED,EXTS,ORDER_NO
from contract_product_c)cp
left join
(select factory_id,full_name,factory_name,contacts,phone from factory_c)f
on cp.factory_id=f.factory_id

然后我们将附件和生产厂家拼接起来:

selectext.EXT_CPRODUCT_ID,ext.CONTRACT_PRODUCT_ID,ext.CTYPE,ext.PRODUCT_NO,ext.PRODUCT_IMAGE,ext.PRODUCT_DESC,ext.CNUMBER,
  ext.PACKING_UNIT,ext.PRICE,ext.AMOUNT,ext.PRODUCT_REQUEST,ext.ORDER_NO,
  f.factory_id,f.full_name,f.factory_name,f.contacts,f.phone
from
(select
EXT_CPRODUCT_ID,CONTRACT_PRODUCT_ID,FACTORY_ID,
CTYPE,PRODUCT_NO,PRODUCT_IMAGE,PRODUCT_DESC,CNUMBER,PACKING_UNIT,PRICE,AMOUNT,PRODUCT_REQUEST,ORDER_NO
from ext_cproduct_c)ext
left join
(select factory_id,full_name,factory_name,contacts,phone from factory_c)f
on ext.factory_id=f.factory_id

接下来继续滚雪球,我们要把上面两段SQL给拼接起来:

select
c.contract_id,c.offeror,c.contract_no,c.signing_date,c.input_by,c.check_by,c.inspector,c.total_amount,c.import_num,
c.crequest,c.custom_name,c.delivery_period,c.ship_time,c.trade_terms,c.remark,c.print_style,c.old_state,c.state,
c.out_state,c.create_by,c.create_dept,c.create_time,

t.contract_product_id,
t.product_no,t.product_image,t.product_desc,t.cnumber,t.out_number,t.loading_rate,t.box_num,t.packing_unit,t.price,t.amount,
t.finished,t.exts,t.cp_order_no,t.factory_id,t.full_name,t.factory_name,t.contacts,t.phone,

t.ext_cproduct_id,
t.ctype,t.ext_product_no,t.ext_product_image,t.ext_product_desc,t.ext_cnumber,t.ext_packing_unit,t.ext_price,t.ext_amount,
t.ext_product_request,t.ext_order_no,t.ext_factory_id,t.ext_full_name,t.ext_factory_name,t.ext_contacts,t.ext_phone
from
(
  select
  contract_id,offeror,contract_no,signing_date,input_by,check_by,inspector,total_amount,import_num,crequest,custom_name,delivery_period,
  ship_time,trade_terms,remark,print_style,old_state,state,out_state,create_by,create_dept,create_time
  from contract_c
)c
left join
(
  select
    cp.contract_product_id,cp.contract_id,
    cp.product_no,cp.product_image,cp.product_desc,cp.cnumber,cp.out_number,cp.loading_rate,cp.box_num,cp.packing_unit,cp.price,
    cp.amount,cp.finished,cp.exts,cp.order_no as cp_order_no,
    cp.factory_id,cp.full_name,cp.factory_name,cp.contacts,cp.phone,

    ext.ext_cproduct_id,ext.ctype,ext.product_no as ext_product_no,ext.product_image as ext_product_image,
    ext.product_desc as ext_product_desc,ext.cnumber as ext_cnumber,ext.packing_unit as ext_packing_unit,ext.price as ext_price,
    ext.amount as ext_amount,ext.product_request as ext_product_request,ext.order_no as ext_order_no,
    ext.factory_id as ext_factory_id,ext.full_name as ext_full_name,ext.factory_name as ext_factory_name,
    ext.contacts as ext_contacts,ext.phone as ext_phone
  from
  (
      select
        cp.contract_product_id,cp.contract_id,
        cp.product_no,cp.product_image,cp.product_desc,cp.cnumber,cp.out_number,cp.loading_rate,cp.box_num,cp.packing_unit,cp.price,cp.amount,cp.finished,cp.exts,cp.order_no,
        f.factory_id,f.full_name,f.factory_name,f.contacts,f.phone
      from
      (select
      contract_product_id,contract_id,factory_id,
      product_no,product_image,product_desc,cnumber,out_number,loading_rate,box_num,packing_unit,price,amount,finished,exts,order_no
      from contract_product_c)cp
      left join
      (select factory_id,full_name,factory_name,contacts,phone from factory_c)f
      on cp.factory_id=f.factory_id
  )cp
  left join
  (
      select
        ext.ext_cproduct_id,ext.contract_product_id,ext.ctype,ext.product_no,ext.product_image,ext.product_desc,ext.cnumber,
        ext.packing_unit,ext.price,ext.amount,ext.product_request,ext.order_no,
        f.factory_id,f.full_name,f.factory_name,f.contacts,f.phone
      from
      (select
      ext_cproduct_id,contract_product_id,factory_id,
      ctype,product_no,product_image,product_desc,cnumber,packing_unit,price,amount,product_request,order_no
      from ext_cproduct_c)ext
      left join
      (select factory_id,full_name,factory_name,contacts,phone from factory_c)f
      on ext.factory_id=f.factory_id
  )ext
  on cp.contract_product_id=ext.contract_product_id
)t
on c.contract_id=t.contract_id

过程中可能会出现这样的错误

说明你的SQL语句里有重复字段,需要加别名

接下来我们开始配置这个查询语句,在ContractMapper.xml中加入一下配置语句:

<select id="view" parameterType="string" resultMap="ContractVORM">
	select
	c.contract_id,c.offeror,c.contract_no,c.signing_date,c.input_by,c.check_by,c.inspector,c.total_amount,c.import_num,
	c.crequest,c.custom_name,c.delivery_period,c.ship_time,c.trade_terms,c.remark,c.print_style,c.old_state,c.state,
	c.out_state,c.create_by,c.create_dept,c.create_time,

	t.contract_product_id,
	t.product_no,t.product_image,t.product_desc,t.cnumber,t.out_number,t.loading_rate,t.box_num,t.packing_unit,t.price,t.amount,
	t.finished,t.exts,t.cp_order_no,t.factory_id,t.full_name,t.factory_name,t.contacts,t.phone,

	t.ext_cproduct_id,
	t.ctype,t.ext_product_no,t.ext_product_image,t.ext_product_desc,t.ext_cnumber,t.ext_packing_unit,t.ext_price,t.ext_amount,
	t.ext_product_request,t.ext_order_no,t.ext_factory_id,t.ext_full_name,t.ext_factory_name,t.ext_contacts,t.ext_phone
	from
	(
	  select
	  contract_id,offeror,contract_no,signing_date,input_by,check_by,inspector,total_amount,import_num,crequest,custom_name,delivery_period,
	  ship_time,trade_terms,remark,print_style,old_state,state,out_state,create_by,create_dept,create_time
	  from contract_c
	)c
	left join
	(
	  select
	    cp.contract_product_id,cp.contract_id,
	    cp.product_no,cp.product_image,cp.product_desc,cp.cnumber,cp.out_number,cp.loading_rate,cp.box_num,cp.packing_unit,cp.price,
	    cp.amount,cp.finished,cp.exts,cp.order_no as cp_order_no,
	    cp.factory_id,cp.full_name,cp.factory_name,cp.contacts,cp.phone,

	    ext.ext_cproduct_id,ext.ctype,ext.product_no as ext_product_no,ext.product_image as ext_product_image,
	    ext.product_desc as ext_product_desc,ext.cnumber as ext_cnumber,ext.packing_unit as ext_packing_unit,ext.price as ext_price,
	    ext.amount as ext_amount,ext.product_request as ext_product_request,ext.order_no as ext_order_no,
	    ext.factory_id as ext_factory_id,ext.full_name as ext_full_name,ext.factory_name as ext_factory_name,
	    ext.contacts as ext_contacts,ext.phone as ext_phone
	  from
	  (
	      select
	        cp.contract_product_id,cp.contract_id,
	        cp.product_no,cp.product_image,cp.product_desc,cp.cnumber,cp.out_number,cp.loading_rate,cp.box_num,cp.packing_unit,cp.price,cp.amount,cp.finished,cp.exts,cp.order_no,
	        f.factory_id,f.full_name,f.factory_name,f.contacts,f.phone
	      from
	      (select
	      contract_product_id,contract_id,factory_id,
	      product_no,product_image,product_desc,cnumber,out_number,loading_rate,box_num,packing_unit,price,amount,finished,exts,order_no
	      from contract_product_c)cp
	      left join
	      (select factory_id,full_name,factory_name,contacts,phone from factory_c)f
	      on cp.factory_id=f.factory_id
	  )cp
	  left join
	  (
	      select
	        ext.ext_cproduct_id,ext.contract_product_id,ext.ctype,ext.product_no,ext.product_image,ext.product_desc,ext.cnumber,
	        ext.packing_unit,ext.price,ext.amount,ext.product_request,ext.order_no,
	        f.factory_id,f.full_name,f.factory_name,f.contacts,f.phone
	      from
	      (select
	      ext_cproduct_id,contract_product_id,factory_id,
	      ctype,product_no,product_image,product_desc,cnumber,packing_unit,price,amount,product_request,order_no
	      from ext_cproduct_c)ext
	      left join
	      (select factory_id,full_name,factory_name,contacts,phone from factory_c)f
	      on ext.factory_id=f.factory_id
	  )ext
	  on cp.contract_product_id=ext.contract_product_id
	)t
	on c.contract_id=t.contract_id

	where c.contract_id=#{contractId}
</select>

然后我们开始写我们的Dao层

在ContractDao接口中加入下面方法:

//查询合同加关联关系的详细信息
public ContractVO view(String contractId);

然后在实现类ContractDaoImpl中加入以下方法

@Override
public ContractVO view(String contractId) {
	return super.getSqlSession().selectOne(super.getNs()+".view", contractId);
}

接下来写Service层

在ContractService接口中添加以下方法

public ContractVO view(String contractId); //带关联对象的查询

然后在实现类ContractServiceImpl中加入以下方法

@Override
public ContractVO view(String contractId) {
	return contractDao.view(contractId);
}

之后使我们的Controller层,我们修改我们之前写的查看方法

//查看方法
@RequestMapping("/cargo/contract/toview.action")
public String toview(String id,Model model){
	ContractVO obj=contractService.view(id);
	model.addAttribute("obj", obj);

	return "/cargo/contract/jContractView.jsp";
}

此时,我们之前的查看页面jContractView.jsp界面就不满足我们的需求了,我们同样要对它进行修改(我们在购销合同下面放置该合同下的货物列表,在每个货物下面放置了每个货物的附件信息):

<%@ page language="java" pageEncoding="UTF-8"%>
<%@ include file="../../base.jsp"%>
<%@ include file="../../baselist.jsp"%>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>查看购销合同</title>
    <script language="javascript" src="${ctx}/js/datepicker/WdatePicker.js"></script>
</head>
<body>
<form method="post">

<div id="menubar">
<div id="middleMenubar">
<div id="innerMenubar">
    <div id="navMenubar">
<ul>
<li id="back"><a href="list.action">返回</a></li>
</ul>
    </div>
</div>
</div>
</div>

<div class="textbox" id="centerTextbox">

    <div class="textbox-header">
    <div class="textbox-inner-header">
    <div class="textbox-title">
		查看购销合同信息
    </div>
    </div>
    </div>
<div>

<div>
		<table class="commonTable" cellspacing="1">
		        <tr>
		        	<td class="columnTitle_mustbe">客户名称:</td>
		            <td class="tableContent">${obj.customName }</td>
		            <td class="columnTitle_mustbe">收购方:</td>
		            <td class="tableContent">${obj.offeror }</td>
		        </tr>

		        <tr>
		        	<td class="columnTitle_mustbe">合同号:</td>
		            <td class="tableContent">${obj.contractNo }</td>
		            <td class="columnTitle_mustbe">签单日期:</td>
		            <td class="tableContent">
		            <fmt:formatDate value="${obj.signingDate }" pattern="yyyy-MM-dd"/>
		            </td>
		        </tr>

		        <tr>
		         	<td class="columnTitle_mustbe">制单人:</td>
		            <td class="tableContent">${obj.inputBy }</td>
		            <td class="columnTitle_mustbe">审单人:</td>
		            <td class="tableContent">${obj.checkBy }</td>
		        </tr>

		         <tr>
		         	<td class="columnTitle_mustbe">验货员:</td>
		            <td class="tableContent">${obj.inspector }</td>
		            <td class="columnTitle_mustbe">总金额:</td>
		            <td class="tableContent">${obj.totalAmount}</td>
		        </tr>

		         <tr>
		            <td class="columnTitle_mustbe">要求:</td>
		            <td class="tableContent">${obj.crequest}</td>
		            <td class="columnTitle_mustbe">交货期限:</td>
		            <td class="tableContent">
		            <fmt:formatDate value="${obj.deliveryPeriod }" pattern="yyyy-MM-dd"/>
		            </td>
		        </tr>

		        <tr>
		            <td class="columnTitle_mustbe">船期:</td>
		            <td class="tableContent">
		            <fmt:formatDate value="${obj.shipTime}" pattern="yyyy-MM-dd"/>
		            </td>
		            <td class="columnTitle_mustbe">贸易条款:</td>
		            <td class="tableContent">${obj.tradeTerms }</td>
		        </tr>

		        <tr>
		            <td class="columnTitle_mustbe">打印版式:</td>
		            <td class="tableContent">
		            <c:if test="${obj.printStyle=='2'}">两款</c:if>
		            <c:if test="${obj.printStyle=='1'}">一款</c:if>
		            </td>
		            <td class="columnTitle_mustbe">归档前状态:</td>
		            <td class="tableContent">${obj.oldState}</td>
		        </tr>

		        <tr>
		            <td class="columnTitle_mustbe">状态:</td>
		            <td class="tableContent">${obj.state}</td>
		            <td class="columnTitle_mustbe">走货状态:</td>
		            <td class="tableContent">${obj.outState}</td>
		        </tr>

		        <tr>
		            <td class="columnTitle_mustbe">重要程度:</td>
		            <td class="tableContent">
		            <c:if test="${obj.importNum==3}">★★★</c:if>
		            <c:if test="${obj.importNum==2}">★</c:if>
		            <c:if test="${obj.importNum==1}">★</c:if>
		            </td>
		        </tr>

		        <tr>
		            <td class="columnTitle_mustbe">说明:</td>
		            <td class="tableContent"><pre>${obj.remark}</pre></td>
		        </tr>
			</table>
	</div>
</div>

<div class="textbox" id="centerTextbox">
  <div class="textbox-header">
  <div class="textbox-inner-header">
  <div class="textbox-title">
  	货物列表
  </div>
  </div>
  </div>

<div>
<div class="eXtremeTable" >
<table id="ec_table" class="tableRegion" width="98%" >
	<thead>
	<tr>
		<td class="tableHeader">序号</td>
		<td class="tableHeader">厂家名称</td>
		<td class="tableHeader">货号</td>
		<td class="tableHeader">数量</td>
		<td class="tableHeader">包装单位</td>
		<td class="tableHeader">装率</td>
		<td class="tableHeader">箱数</td>
		<td class="tableHeader">单价</td>
		<td class="tableHeader">总金额</td>
	</tr>
	</thead>
	<tbody class="tableBody" >

	<c:forEach items="${obj.contractProducts}" var="cp" varStatus="status">
	<tr class="odd" onmouseover="this.className='highlight'" onmouseout="this.className='odd'" >
		<td>${status.index+1}</td>
		<td>${cp.factory.factoryName}</td>
		<td>${cp.productNo}</td>
		<td>${cp.cnumber}</td>
		<td>${cp.packingUnit}</td>
		<td>${cp.loadingRate }</td>
		<td>${cp.boxNum }</td>
		<td>${cp.price }</td>
		<td>${cp.amount}</td>
	</tr>
		<c:forEach items="${cp.extCproducts}" var="ext" varStatus="status">
		<tr class="odd" onmouseover="this.className='highlight'" onmouseout="this.className='odd'" >
			<td><font color="blue">附件:${status.index+1}</font></td>
			<td>${ext.factory.factoryName}</td>
			<td>${ext.productNo}</td>
			<td>${ext.cnumber}</td>
			<td>${ext.packingUnit}</td>
			<td> </td>
			<td> </td>
			<td>${ext.price }</td>
			<td>${ext.amount}</td>
		</tr>
		</c:forEach>
	</c:forEach>

	</tbody>
</table>
</div>

</div>

</form>
</body>
</html>

下面我们来测试

先打开购销合同列表,这里有两个购销合同,我们可以发现,第一个购销合同有2个货物和3个附件:

点击查看之后获取到这个页面:

我们可以清晰的看到购销合同的详细信息和购销合同下的货物的列表,以及每个货物的附件信息:

至此,我们的购销合同关联关系信息的查询功能完成!

注:此篇一定要反复看,SQL语句一定要自己敲一遍,SQL语句一定要自己敲一遍,SQL语句一定要自己敲一遍(重要的事情说三遍)

转载请注明出处:http://blog.csdn.net/acmman/article/details/48649815

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-08-03 18:35:02

【springmvc+mybatis项目实战】杰信商贸-22.合同货物附件生产厂家mapper关联的相关文章

【springmvc+mybatis项目实战】杰信商贸-20.合同货物数和附件数

我们上一篇完成了购销合同.货物以及附件的级联删除,这次我们需要做的业务就是----要求直接显示合同下的货物数和附件数 上一次我们遗留的问题: 我们每次删除完都要去下一级或者数据库看看我们删除了没有,我们可以直接在合同列表中显示每个合同下的货物以及货物的附件有多少件,这样就避免了反复去下一级查看列表的繁琐操作. 那么下面我们使用SQL来编写获取合同下的货物数: select count(*) from contract_product_c where contract_id='928eb2ae-2

【springmvc+mybatis项目实战】杰信商贸-8.生产厂家修改

上一次我们做了生产厂家的新增,下面我们来做一下生产厂家的修改 回顾一下我们的FactoryMapper.xml: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

【springmvc+mybatis项目实战】杰信商贸-6.重点知识回顾

1.重点知识回顾 Maven 1)覆盖仓库文件,实际企业开发,公司会架一个测试服务器,在测试服务器中架私服.我们开发人员的程序,都连接私服.当本地没有项目中要使用的jar,Myeclipse maven插件会自动到私服去找jar,如果没找到去中央仓库maven寻找,找到后下载.activiti-engine-5.13.jar.lastUpdated 当访问远程仓库时,由于网络不稳定,有可能中断.当程序再次连接,它会自动修正.Pom文件报错,jar错误,去仓库目录找jar,jar存在,点击jar开

【springmvc+mybatis项目实战】杰信商贸-7.生产厂家新增

我们来接着我们的项目写 我们要实现新的功能,就是生产厂家的新增 先来回顾一下系统架构图 我们数据库这边已经建好表了,接下来要做的就是mapper映射 编辑FactoryMapper.xml文件,加入"添加"的逻辑配置代码块 <!-- 新增 oracle jbdc驱动当这个值为null时,必须告诉它当前字段 默认值的类型jdbcType=VARCHAR(MyBatis定义),Mysql不用写--> <insert id="insert" parame

【springmvc+mybatis项目实战】杰信商贸-30.出口报运增删查修mapper+Dao+Service+Controller

我们接下来做我们项目的下一个环节,就是出口报运的业务,首先我们来看看两个设计方式 a)大型项目设计方式 传统设计方式,基于对象关联,数据量小时,系统无碍:当数据随着系统的使用,线性增长,系统变的越来越慢,到达一定数据量时,性能急剧下降. b)新的设计方式:打断设计 在表中增加一个字段,这个字段用来存储关联表的主键集合:在报运业务中要查询合同下的货物信息.直接通过这个关联字段,利用in子查询直接去查询货物表,这样查询效率提高很多.而且数据量越大,查询效率越高.这种方式,业务关联层级越多,这种设计方

【springmvc+mybatis项目实战】杰信商贸-34.业务出口报运WebService1

我们要为出口报运做一个WebService,来提供跨系统的信息查询功能. 我们使用的技术是 -------Apache CXF WebService 作用:两个异构系统,需要共享数据. 需求:我们要给客户提供合同追踪.在出口报运中增加一个WebService,用户可以通过它的系统来访问这个服务,展现出口报运单,主要可以浏览用户的订单状态(走到哪个流程).查看出口报运单 开发步骤:将现有的Service改造成WebService 1)将CXF整合到项目中,加入jar包.依赖jar.我们系统才 CX

【springmvc+mybatis项目实战】杰信商贸-23.重点知识回顾

1.重点知识回顾 购销合同查看,采用类似hibernate方式,都以对象关联方式. (1)PO为了利用MyBatis性能,在创建时,没有采用关联对象关联,而是将对象关键字段,也就是外键,利用这个普通属性,来记录值,表数据间关联关系存在,但对象关联关系不存在.代码也就变得简单.在货物新增时,只要从主对象中携带过来,主表ID即可. (2)VO为了方便对象关联时取数据.在列表循环货物信息时,要去查询当前货物下的附件时,如果采用上面的方式,只能再次查询.但是我们以对象关联方式,可以直接获取到当前货物下的

【springmvc+mybatis项目实战】杰信商贸-35.业务出口报运WebService2

我们上一次创建了出口报运的WebService的搭建,测试的时候,我们仅仅得到了WebService给我们回复的soap结构的XML对象,但是我们没有去解析.下面我们来完成soap的XML的解析,并把相应的数据通过javascript安插在table中. 我们先来分析一下之前我们saop发出的XML请求和得到的XML回复的例子 请求: <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/&quo

【springmvc+mybatis项目实战】杰信商贸-25.出货表打印

我们之前学习了POI技术,可以利用POI进行自定义excel文件的生成.我们接下来就将利用这一技术来实现我们的出货表的打印. 回顾一下我们的出货表 我们将利用POI构造这样一个excel文档,然后将它生成. 我们先从头来分析,"2012年8月份出货表"是一个标题,并且合并了单元格,我们应该怎么做呢? 我们的出货表的开发步骤如下 1.获取数据 2.创建excel文件 3.将数据写入excel文件 先从"获取数据"开始,我们的出货表是按照月份出货的,所以我们要先编写一个