| using System; | 
| using System.Collections.Generic; | 
| using System.Data; | 
| using System.Linq; | 
| using System.Web; | 
|   | 
| namespace WebAPI.DLL | 
| { | 
|     public class ClsSc_MESReturnStepWorkBill : DBUtility.ClsXt_BaseBill | 
|     { | 
|         public Model.ClsSc_ProcessPlanMain omodel = new Model.ClsSc_ProcessPlanMain(); | 
|         public List<Model.ClsSc_ProcessPlanSub> DetailColl = new List<Model.ClsSc_ProcessPlanSub>(); | 
|         //public List<Model.ClsSc_MESBeginWorkBillSub_Item> DetailColl1 = new List<Model.ClsSc_MESBeginWorkBillSub_Item>(); | 
|         public ClsSc_MESReturnStepWorkBill() | 
|         { | 
|             base.MvarItemKeySub = "Sc_ProcessPlanSub"; | 
|             base.MvarItemKeySub2 = ""; | 
|             base.MvarItemKeySub3 = ""; | 
|             base.MvarItemKeySub4 = ""; | 
|             base.MvarItemKey = "Sc_ProcessPlanMain"; | 
|             base.MvarReportTitle = "返工单"; | 
|             base.BillType = "3718"; | 
|             base.HBillSubType = "3718"; | 
|   | 
|         } | 
|   | 
|         #region 固定代码 | 
|   | 
|         ~ClsSc_MESReturnStepWorkBill() | 
|         { | 
|             DetailColl = null; | 
|         } | 
|   | 
|         #endregion   自定义方法 | 
|   | 
|         //修改单据 | 
|         public override bool ModifyBill(Int64 lngBillKey, ref string sReturn) | 
|         { | 
|             try | 
|             { | 
|                 // | 
|                 oCn.BeginTran(); | 
|                 //更新主表 | 
|                 oCn.RunProc("UpDate Sc_ProcessPlanMain set  " + | 
|                 " HBillNo='" + omodel.HBillNo + "'" +  //固定赋值=============== | 
|                 ",HDate='" + omodel.HDate + "'" + | 
|                 ",HYear='" + omodel.HYear.ToString() + "'" + | 
|                 ",HPeriod='" + omodel.HPeriod.ToString() + "'" + | 
|                 ",HBillStatus='" + omodel.HBillStatus + "'" + | 
|                 ",HRemark='" + omodel.HRemark + "'" + | 
|                 ",HUpDater='" + DBUtility.ClsPub.CurUserName + "'" + | 
|                 ",HUpDateDate=getdate()" + | 
|                 //======================================== | 
|                 //",HSupID=" + omodel.HSupID.ToString() + | 
|                 //",HEmpID=" + omodel.HEmpID.ToString() + | 
|                 ",HICMOInterID=" + omodel.HICMOInterID.ToString() + | 
|                 ",HICMOBillNo='" + omodel.HICMOBillNo + "'" + | 
|                 ",HMaterID=" + omodel.HMaterID.ToString() + | 
|                 " where HInterID=" + lngBillKey.ToString()); | 
|                 //删除关联 | 
|                 DeleteRelation(ref sReturn, lngBillKey); | 
|                 //删除子表 | 
|                 DeleteBillSub(lngBillKey); | 
|                 //插入子表 | 
|                 omodel.HInterID = lngBillKey; | 
|                 //插入子表 | 
|                 oCn.RunProc("Insert Into Sc_ProcessPlanSub " + | 
|                     "(HInterID,HEntryID,HBillNo" + | 
|                     ",HICMOInterID,HICMOBillNo,HProcNo,HProcID" + | 
|                     ",HGroupID,HDeptID,HWorkerID,HQty,HPlanBeginDate,HSourceInterID,HSourceEntryID,HSourceBillNo,HSourceBillType" + | 
|                     ") " + | 
|                     " values(" + omodel.HInterID.ToString() + ",0,'" + omodel.HBillNo + | 
|                     "'," + omodel.HICMOInterID.ToString() + ",'" + omodel.HICMOBillNo + "','" + omodel.HProcNo + "'," + omodel.HProcID.ToString() + "," + omodel.HGroupID.ToString() + | 
|                     "," + omodel.HDeptID.ToString() + "," + omodel.HWorkerID.ToString() + "," + omodel.HQty.ToString() + ",'" + omodel.HPlanBeginDate.ToString() + "'," + omodel.HSourceInterID.ToString() + | 
|                     "," + omodel.HSourceEntryID.ToString() + ",'" + omodel.HSourceBillNo + "','" + omodel.HSourceBillType + | 
|                      "') "); | 
|                 sReturn = "修改单据成功!"; | 
|                 oCn.Commit(); | 
|                 return true; | 
|             } | 
|             catch (Exception e) | 
|             { | 
|                 sReturn = e.Message; | 
|                 oCn.RollBack(); | 
|                 throw (e); | 
|             } | 
|         } | 
|         //新增单据 | 
|         public override bool AddBill(ref string sReturn) | 
|         { | 
|             try | 
|             { | 
|                 //获取当前工序工序号以及判断是否末道工序 | 
|                 string sql = string.Format(@"select max(b.HProcNo) HProcNo  from Sc_ProcessPlanMain a | 
|                                inner join   Sc_ProcessPlanSub  b on a.HInterID=b.HInterID   | 
|                                where b.HSourceBillNo='" + omodel.HSourceBillNo+"' and b.HSourceInterID='"+omodel.HSourceInterID+"'  and b.HSourceEntryID='"+omodel.HSourceEntryID+"'"); | 
|                 DataSet ds= oCn.RunProcReturn(sql, "Sc_ProcessPlanMain"); | 
|                 //查询最大工序及判断当前工序是否小于最大工序 | 
|                 if (ds.Tables[0].Rows.Count > 0 && int.Parse(ds.Tables[0].Rows[0]["HProcNo"].ToString()) > omodel.HProcID) | 
|                 { | 
|                     omodel.HProcNo = omodel.HProcNo + 5; | 
|                 } | 
|                 else  | 
|                 { | 
|                     omodel.HProcNo = omodel.HProcNo + 5; //末道工序序号加5 | 
|                 } | 
|   | 
|                 //得到mainid | 
|                 omodel.HInterID = DBUtility.ClsPub.CreateBillID(BillType, ref DBUtility.ClsPub.sExeReturnInfo); | 
|                 //若MAINDI重复则重新获取 | 
|                 oCn.BeginTran(); | 
|                 //主表 | 
|                 oCn.RunProc("Insert Into Sc_ProcessPlanMain " + | 
|                 "(HBillType,HBillSubType,HInterID,HBillNo,HBillStatus,HDate,HMaker,HMakeDate" + | 
|                 ",HYear,HPeriod,HRemark" + | 
|                 ",HICMOInterID,HICMOBillNo,HMaterID" + | 
|                 ") " + | 
|                 " values('" + this.BillType + "','" + this.HBillSubType + "'," + omodel.HInterID.ToString() + ",'" + omodel.HBillNo + "'," + omodel.HBillStatus.ToString() + ",getdate(),'" + DBUtility.ClsPub.CurUserName + "',getdate()" + | 
|                 "," + omodel.HYear.ToString() + "," + omodel.HPeriod.ToString() + ",'" + omodel.HRemark + "'" + | 
|                 "," + omodel.HICMOInterID.ToString() + ",'" + omodel.HICMOBillNo + "'," +  omodel.HMaterID.ToString() +  | 
|                  ") "); | 
|                 //插入子表 | 
|                 oCn.RunProc("Insert Into Sc_ProcessPlanSub " + | 
|                     "(HInterID,HEntryID,HBillNo" + | 
|                     ",HICMOInterID,HICMOBillNo,HProcNo,HProcID" + | 
|                     ",HGroupID,HDeptID,HWorkerID,HQty,HPlanBeginDate,HSourceInterID,HSourceEntryID,HSourceBillNo,HSourceBillType,HSourceID" + | 
|                     ") " + | 
|                     " values(" + omodel.HInterID.ToString() + ",0,'" + omodel.HBillNo + | 
|                     "'," + omodel.HICMOInterID.ToString() + ",'" + omodel.HICMOBillNo + "','" + omodel.HProcNo + "'," + omodel.HProcID.ToString() + "," + omodel.HGroupID.ToString() + | 
|                     "," + omodel.HDeptID.ToString() + "," + omodel.HWorkerID.ToString() + "," + omodel.HQty.ToString() + ",'" + omodel.HPlanBeginDate.ToString() +"',"+ omodel.HSourceInterID.ToString()+ | 
|                     ","+ omodel.HSourceEntryID.ToString()+",'"+ omodel.HSourceBillNo+"','"+ omodel.HSourceBillType+","+ omodel.HSourceID.ToString()+ | 
|                      ") "); | 
|                 //新增生产状态临时表 | 
|                 string sql1 = string.Format(@"insert into Sc_ICMOBillStatus_Tmp(HYear,HPeriod,HBillType,HDate,HDeptID,HICMOInterID,HICMOEntryID,HICMOBillNo,HYX,HSplitNO,HICMOStatus,HMaterID | 
|                                     ,HMaterNumber,HUnitID,HUnitNumber,HSourceID,HSourceNumber,HSplitPlanQty,HSplitRelationQty,HDatePlanQty | 
|                                     ,HUnitFinishQty,HDateFinishQty,HBadQty,HUnitBadQty,HWasterQty,HSumTimes,HFinishFlag,HCurWorkFlag,HCurQualityFlag | 
|                                     ,HBeginDate,HEndDate,HRemark,HSourceInterID,HSourceEntryID,HSourceBillNo | 
|                                     ,HSourceBillType,HRelationInterID,HEnoughMaterFlag,HProcID,HPlanQty) | 
|                                     select HYear,HPeriod,HBillType,HDate,HDeptID,HICMOInterID,HICMOEntryID,HICMOBillNo,HYX,HSplitNO,HICMOStatus,HMaterID | 
|                                     ,HMaterNumber,HUnitID,HUnitNumber,HSourceID,HSourceNumber,HPlanQty,HSplitPlanQty,HSplitRelationQty,HDatePlanQty | 
|                                     ,HUnitFinishQty,HDateFinishQty,HBadQty,HUnitBadQty,HWasterQty,HSumTimes,HFinishFlag,HCurWorkFlag,HCurQualityFlag | 
|                                     ,HBeginDate,HEndDate,HRemark,HSourceInterID,HSourceEntryID,HSourceBillNo | 
|                                     ,HSourceBillType,HRelationInterID,HEnoughMaterFlag,HProcID,'"+omodel.HQty.ToString()+"' " + | 
|                                     "from Sc_ICMOBillStatus_Tmp where HSourceBillNo='"+omodel.HSourceBillNo.ToString()+"'" + | 
|                                     " and HSourceInterID='"+omodel.HSourceInterID+"' and HSourceEntryID='"+omodel.HMainSourceEntryID.ToString()+"'" + | 
|                                     " and HSourceID='"+omodel.HSourceID.ToString()+"' and HProcID='"+omodel.HProcID.ToString()+"'"); | 
|                 oCn.RunProc(sql); | 
|                 sReturn = "新增单据成功!"; | 
|                 oCn.Commit(); | 
|                 return true; | 
|             } | 
|             catch (Exception e) | 
|             { | 
|                 sReturn = e.Message; | 
|                 oCn.RollBack(); | 
|                 throw (e); | 
|             } | 
|         } | 
|     } | 
| } |