标签:mybatis oracle plsql developer powerdesigner spring mvc
我们上一次完成了合同的总金额的计算,我们这次继续完成一个新的更复杂,但是更有学习意义的业务---购销合同查看要求:查看合同的主信息,查看合同下的货物信息,还要查看附件信息,货物和附件的信息要显示出它们的关联关系。
(注:一个合同下有多个货物,每个货物又有每个货物自己的附件)
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方法省略 }
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方法省略 }
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方法省略 }
<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>
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
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
<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>
//查询合同加关联关系的详细信息 public ContractVO view(String contractId);
@Override public ContractVO view(String contractId) { return super.getSqlSession().selectOne(super.getNs()+".view", contractId); }
public ContractVO view(String contractId); //带关联对象的查询
@Override public ContractVO view(String contractId) { return contractDao.view(contractId); }
//查看方法 @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"; }
<%@ 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>
注:此篇一定要反复看,SQL语句一定要自己敲一遍,SQL语句一定要自己敲一遍,SQL语句一定要自己敲一遍(重要的事情说三遍)
转载请注明出处:http://blog.csdn.net/acmman/article/details/48649815
版权声明:本文为博主原创文章,未经博主允许不得转载。
【springmvc+mybatis项目实战】杰信商贸-22.合同货物附件生产厂家mapper关联
标签:mybatis oracle plsql developer powerdesigner spring mvc
原文地址:http://blog.csdn.net/acmman/article/details/48649815