yusijie
2022-12-02 9a25374232885701044aece4ffab722bb5ca50f0
生产用料清单
2个文件已添加
2个文件已修改
467 ■■■■■ 已修改文件
Model/Model.csproj 2 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Model/生产管理/ClsSc_PPBomBillMain.cs 58 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Model/生产管理/ClsSc_PPBomBillSub.cs 76 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
WebAPI/Controllers/SCGL/Sc_PPBomBillController.cs 331 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Model/Model.csproj
@@ -432,6 +432,8 @@
    <Compile Include="生产管理\ClsSc_ChangeNoteBillSub.cs" />
    <Compile Include="生产管理\ClsSc_MateWasterRequestBillMain.cs" />
    <Compile Include="生产管理\ClsSc_MateWasterRequestBillSub.cs" />
    <Compile Include="生产管理\ClsSc_PPBomBillMain.cs" />
    <Compile Include="生产管理\ClsSc_PPBomBillSub.cs" />
    <Compile Include="生产管理\ClsSc_WIPStockChangeBillMain.cs" />
    <Compile Include="生产管理\ClsSc_WIPStockChangeBillSub.cs" />
    <Compile Include="生产管理\ClsSc_WIPStockCheckBillMain.cs" />
Model/Éú²ú¹ÜÀí/ClsSc_PPBomBillMain.cs
New file
@@ -0,0 +1,58 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Model.生产管理
{
    public class ClsSc_PPBomBillMain : DBUtility.ClsXt_BaseBillMain
    {
        public string HBillNo;     //单据号
        public Int64 HMaterID;  //物料
        public Int64 HUnitID;  //计量单位
        public Int64 HDeptID;    //部门
        public DateTime HDate;  //日期
        public double HQty;  //数量
        public string HRemark;   //备注
        public Int64 HYear;
        public Int64 HPeriod;
        public string HBillType; // å•据类型
        public string HBillSubType; // å­ç±»åž‹
        public Int64 HInterID;
        public Int64 HBillStatus;        //单据状态
        public Int64 HCheckItemNextID;  //待审核项目(默认值 0)    ç•Œé¢ä¸Šä¸éœ€è¦æ˜¾ç¤º
        public Int64 HCheckFlowID;  //审批流(默认值 0)  ç•Œé¢ä¸Šä¸éœ€è¦æ˜¾ç¤º
        public string HBacker; //退回人  ï¼ˆé»˜è®¤ä¸º'')
        public string HBackDate;  //退回日期 ï¼ˆå…è®¸NULL)
        public string HChecker;   //审核人 ï¼ˆé»˜è®¤ä¸º'')
        public string HCheckDate;          //审核日期 ï¼ˆå…è®¸NULL)
        public string HMaker;          //制单人
        public string HMakeDate;             //制单日期
        public string HUpDater;                 //修改人 ï¼ˆé»˜è®¤ä¸º'')
        public string HUpDateDate;         //修改日期 ï¼ˆå…è®¸NULL)
        public string HCloseMan;          //关闭人 ï¼ˆé»˜è®¤ä¸º'')
        public string HCloseDate;         //关闭日期 ï¼ˆå…è®¸NULL)
        public Int64 HCloseType;           //关闭类型   ï¼ˆé»˜è®¤ä¸º0)
        public string HDeleteMan;           //作废人 ï¼ˆé»˜è®¤ä¸º'')
        public string HDeleteDate;           //作废日期 ï¼ˆå…è®¸NULL)
        public Int64 HICMOInterID;  //生产订单内码
        public Int64 HCheckItemNowID;      //当前审核项目(默认值 0)        ç•Œé¢ä¸Šä¸éœ€è¦æ˜¾ç¤º
        public Int64 HSeOrderInterID;  //销售订单内码
        public Int64 HSeOrderEntryID;  //销售订单子内码
        public string HSeOrderBillNo;  //销售订单号
        public string HType; // ç±»åž‹(可能是 å§”外和生产)
        public Int64 HSeOrderEntrySEQ;  //销售订单行号
        public Int64 HICMOEntrySEQ;  //生产订单行号
        public string HREQSRC;   //需求来源
        public Int64 HICMOEntryID;
        public Int64 HPRDORGID;
        public Int64 HENTRUSTORGID;
        public Int64 HPARENTOWNERID;
        public string HPARENTOWNERTYPEID;
        public Int64 HERPInterID;
        public string HERPBillType;
    }
}
Model/Éú²ú¹ÜÀí/ClsSc_PPBomBillSub.cs
New file
@@ -0,0 +1,76 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Model.生产管理
{
    public class ClsSc_PPBomBillSub : DBUtility.ClsXt_BaseBillSub
    {
        public Int64 HMaterID;    //物料ID
        public string HMaterNumber; //
        public Int64 HUnitID;    //单位ID
        public string HUnitNumber; //
        public Int64 HWHID;  //仓库
        public Int64 HSPID;  //仓位
        public Int64 HBASEUNITID; //基本计量单位,
        public double HQty;  //数量
        public string HRemark;            //备注
        public Int64 HQtyMust; //应发数量
        public double HNumerator;  //分子
        public double HDenominator;  //分母
        public double HQtyScrap;  //损耗率
        public DateTime HSendDate;  //发料日期
        public Int64 HBomInterID; //BOM
        public Int64 HProcID;      //工序内码
        public Int64 HKeyMaterID_Line;  //关键件绑定标记
        public Int64 HKeyMaterID_InStock;     //关键件入库标记
        public Int64 HKeyMaterID_Ready;  //关键件齐套标记
        public Int64 HICMOInterID;   //任务单ID
        public string HICMOBillNo;  //任务单号
        public string HSeOrderBillNo;  //(销售订单号)
        public Int64 HSeOrderInterID;    //(销售订单主内码)
        public Int64 HSeOrderEntryID;     //(销售订单子内码)
        public Int64 HChangeTimes;         //变更次数
        public Int64 HProcessID; //作业,
        public Int64 HICMOENTRYSEQ;//生产订单行号,
        public Int64 HICMOEntryID;//生产订单子内码
        public string HPROJECTNO;  //项目编号,
        public Int64 HOPERID;//金蝶工序,
        public Int64 HSEQ;//行号,
        public Int64 HSTOCKSTATUSID; //库存状态,
        public Int64 HLOT; //批次内码,
        public Int64 HOPTQUEUE;//工序序列,
        public Int64 HRESERVETYPE;//预留类型,
        public double HSelPickedQty; //领料选单数量,
        public double HSELPRCDRETURNQTY;  //退料选单数量,
        public Int64 HInterID;
        public Int64 HEntryID;
        public string HCloseMan; //行关闭(默认为'')
        public DateTime HEntryCloseDate;    //行关闭(默认为'')
        public Int64 HCloseType; //关闭类型(默认为0)
        public Int64 HSourceInterID;     //源单ID
        public Int64 HSourceEntryID; //源单子ID
        public string HSourceBillNo; //源单单号
        public string HSourceBillType; //源单类型
        public double HRelationQty;     //关联数量
        public double HRelationMoney; //关联金额
        public Int64 HCHILDSUPPLYORGID;
        public Int64 HSUPPLYORGID;
        public Int64 HENTRUSTPICKORGID;
        public Int64 HSRCTRANSORGID;
        public Int64 HGROUPBYOWNERID;
        public Int64 HOWNERID;
        public Int64 HAuxPropID;
        public Int64 HERPInterID;
        public Int64 HERPEntryID;
        public double HMoveStockQty;
        public double HBackRelationQty;
        public string HOWNERTYPEID;
        public string HBatchNO;
        public string HMTONo;
    }
}
WebAPI/Controllers/SCGL/Sc_PPBomBillController.cs
@@ -1,4 +1,5 @@
using Newtonsoft.Json.Linq;
using Model.生产管理;
using Newtonsoft.Json.Linq;
using Pub_Class;
using System;
using System.Collections;
@@ -240,5 +241,333 @@
            }
        }
        #endregion
        #region ç”Ÿäº§ç”¨æ–™å• ä¿å­˜/编辑功能
        [Route("Sc_PPBomBill/PPBomBillEdit")]
        [HttpPost]
        public object PPBomBillEdit([FromBody] JObject sMainSub)
        {
            try
            {
                var _value = sMainSub["sMainSub"].ToString();
                string msg1 = _value.ToString();
                oCN.BeginTran();
                //保存主表
                objJsonResult = AddBillMain(msg1);
                if (objJsonResult.code == "0")
                {
                    oCN.RollBack();
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = objJsonResult.Message;
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                oCN.Commit();
                objJsonResult.code = "1";
                objJsonResult.count = 1;
                objJsonResult.Message = "单据保存成功!";
                objJsonResult.data = null;
                return objJsonResult;
            }
            catch (Exception e)
            {
                oCN.RollBack();
                objJsonResult.code = "0";
                objJsonResult.count = 0;
                objJsonResult.Message = "保存失败!" + e.ToString();
                objJsonResult.data = null;
                return objJsonResult;
            }
        }
        public json AddBillMain(string msg1)
        {
            string[] sArray = msg1.Split(new string[] { ";" }, StringSplitOptions.RemoveEmptyEntries);
            string msg2 = sArray[0].ToString(); //主表数据
            string msg3 = sArray[1].ToString(); //子表数据
            int OperationType = int.Parse(sArray[2].ToString()); // æ•°æ®ç±»åž‹ 1添加 3修改
            string user = sArray[3].ToString();
            string msg_allVal = sArray[4].ToString(); //主表+子表所有数据
            try
            {
                msg2 = "[" + msg2.ToString() + "]";
                List<ClsSc_PPBomBillMain> mainList = Newtonsoft.Json.JsonConvert.DeserializeObject<List<ClsSc_PPBomBillMain>>(msg2);
                string HBillNo = mainList[0].HBillNo;     //单据号
                long HMaterID = mainList[0].HMaterID;  //物料
                long HUnitID = mainList[0].HUnitID;  //计量单位
                long HDeptID = mainList[0].HDeptID;    //部门
                DateTime HDate = mainList[0].HDate;  //日期
                double HQty = mainList[0].HQty;  //数量
                string HRemark = mainList[0].HRemark;   //备注
                List<ClsSc_PPBomBillMain> mainList2 = Newtonsoft.Json.JsonConvert.DeserializeObject<List<ClsSc_PPBomBillMain>>(msg2);
                DateTime dt = DateTime.Now;
                long HYear = mainList2[0].HYear == null ? 0 : mainList2[0].HYear;
                long HPeriod = mainList2[0].HPeriod == null ? 0 : mainList2[0].HPeriod;
                string HBillType = mainList2[0].HBillType == null ? "''" : mainList2[0].HBillType; // å•据类型
                string HBillSubType = mainList2[0].HBillSubType == null ? "''" : mainList2[0].HBillSubType; // å­ç±»åž‹
                long HInterID = mainList2[0].HInterID == null ? 0 : mainList2[0].HInterID;
                long HBillStatus = mainList2[0].HBillStatus == null ? 0 : mainList2[0].HBillStatus;        //单据状态
                long HCheckItemNextID = mainList2[0].HCheckItemNextID == null ? 0 : mainList2[0].HCheckItemNextID;  //待审核项目(默认值 0)
                long HCheckFlowID = mainList2[0].HCheckFlowID == null ? 0 : mainList2[0].HCheckFlowID;  //审批流(默认值 0)  ç•Œé¢ä¸Šä¸éœ€è¦æ˜¾ç¤º
                string HBacker = mainList2[0].HBacker == null ? "''" : mainList2[0].HBacker; //退回人  ï¼ˆé»˜è®¤ä¸º'')
                string HBackDate = mainList2[0].HBackDate == null ? "''" : mainList2[0].HBackDate;  //退回日期 ï¼ˆå…è®¸NULL)
                string HChecker = mainList2[0].HChecker == null ? "''" : mainList2[0].HChecker;   //审核人 ï¼ˆé»˜è®¤ä¸º'')
                string HCheckDate = mainList2[0].HCheckDate == null ? "''" : mainList2[0].HCheckDate;          //审核日期 ï¼ˆå…è®¸NULL)
                string HMaker = mainList2[0].HMaker == null ? "''" : mainList2[0].HMaker;          //制单人
                string HMakeDate = mainList2[0].HMakeDate == null ? "''" : mainList2[0].HMakeDate;             //制单日期
                string HUpDater = mainList2[0].HUpDater == null ? "''" : mainList2[0].HUpDater;                 //修改人 ï¼ˆé»˜è®¤ä¸º'')
                string HUpDateDate = mainList2[0].HUpDateDate == null ? "''" : mainList2[0].HUpDateDate;         //修改日期 ï¼ˆå…è®¸NULL)
                string HCloseMan = mainList2[0].HCloseMan == null ? "''" : mainList2[0].HCloseMan;          //关闭人 ï¼ˆé»˜è®¤ä¸º'')
                string HCloseDate = mainList2[0].HCloseDate == null ? "''" : mainList2[0].HCloseDate;         //关闭日期 ï¼ˆå…è®¸NULL)
                long HCloseType = mainList2[0].HCloseType == null ? 0 : mainList2[0].HCloseType;           //关闭类型   ï¼ˆé»˜è®¤ä¸º0)
                string HDeleteMan = mainList2[0].HDeleteMan == null ? "''" : mainList2[0].HDeleteMan;           //作废人 ï¼ˆé»˜è®¤ä¸º'')
                string HDeleteDate = mainList2[0].HDeleteDate == null ? "''" : mainList2[0].HDeleteDate;           //作废日期 ï¼ˆå…è®¸NULL)
                long HICMOInterID = mainList2[0].HICMOInterID == null ? 0 : mainList2[0].HICMOInterID;  //生产订单内码
                long HCheckItemNowID = mainList2[0].HCheckItemNowID == null ? 0 : mainList2[0].HCheckItemNowID;      //当前审核项目(默认值 0)
                long HSeOrderInterID = mainList2[0].HSeOrderInterID == null ? 0 : mainList2[0].HSeOrderInterID;  //销售订单内码
                long HSeOrderEntryID = mainList2[0].HSeOrderEntryID == null ? 0 : mainList2[0].HSeOrderEntryID;  //销售订单子内码
                string HSeOrderBillNo = mainList2[0].HSeOrderBillNo == null ? "''" : mainList2[0].HSeOrderBillNo;  //销售订单号
                string HType = mainList2[0].HType == null ? "''" : mainList2[0].HType; // ç±»åž‹(可能是 å§”外和生产)
                long HSeOrderEntrySEQ = mainList2[0].HSeOrderEntrySEQ == null ? 0 : mainList2[0].HSeOrderEntrySEQ;  //销售订单行号
                long HICMOEntrySEQ = mainList2[0].HICMOEntrySEQ == null ? 0 : mainList2[0].HICMOEntrySEQ;  //生产订单行号
                string HREQSRC = mainList2[0].HREQSRC == null ? "''" : mainList2[0].HREQSRC;   //需求来源
                long HICMOEntryID = mainList2[0].HICMOEntryID == null ? 0 : mainList2[0].HICMOEntryID;
                long HPRDORGID = mainList2[0].HPRDORGID == null ? 0 : mainList2[0].HPRDORGID;
                long HENTRUSTORGID = mainList2[0].HENTRUSTORGID == null ? 0 : mainList2[0].HENTRUSTORGID;
                long HPARENTOWNERID = mainList2[0].HPARENTOWNERID == null ? 0 : mainList2[0].HPARENTOWNERID;
                string HPARENTOWNERTYPEID = mainList2[0].HPARENTOWNERTYPEID == null ? "''" : mainList2[0].HPARENTOWNERTYPEID;
                long HERPInterID = mainList2[0].HERPInterID == null ? 0 : mainList2[0].HERPInterID;
                string HERPBillType = mainList2[0].HERPBillType == null ? "''" : mainList2[0].HERPBillType;
                ds = oCN.RunProcReturn("select * from h_v_IF_PPBomBillList where hmainid=" + HInterID + " and å•据号='" + HBillNo + "'", "h_v_IF_PPBomBillList");
                if ((OperationType == 1 || OperationType == 2) && ds.Tables[0].Rows.Count == 0)//新增
                {
                    //主表
                    oCN.RunProc(@"Insert Into Sc_PPBomBillMain
                        (HInterID,HYear,HPeriod,HBillType,HBillSubType,HDate,HBillNo,HBillStatus,HICMOInterID
                        ,HICMOEntryID,HMaterID,HUnitID,HQty,HDeptID,HMaker,HMakeDate,HChecker,HCheckDate
                        ,HSeOrderBillNo,HSeOrderInterID,HSeOrderEntryID,HPRDORGID,HENTRUSTORGID,HPARENTOWNERID
                        ,HPARENTOWNERTYPEID,HERPInterID,HERPBillType,HSeOrderEntrySEQ,HICMOEntrySEQ)
                        values(" + HInterID + "," + DateTime.Now.Year + "," + DateTime.Now.Month + ",'" + 3720 + "','" +
                    HBillSubType + "','" + HDate + "','" + HBillNo + "','" + HBillStatus + "'," + HICMOInterID +
                    "," + HICMOEntryID + ",'" + HMaterID + "'," + HUnitID + "," + HQty + "," + HDeptID +
                    ",'" + HMaker + "','" + HMakeDate + "','" + HChecker + "','" + HCheckDate + "','" + HSeOrderBillNo + "'," + HSeOrderInterID + "," + HSeOrderEntryID + "," + HPRDORGID + "," + HENTRUSTORGID + "," + HPARENTOWNERID + "," +
                    HPARENTOWNERTYPEID + "," + HERPInterID + ",'" + HERPBillType + "'," + HSeOrderEntrySEQ + "," + HICMOEntrySEQ + ")");
                }
                else if (OperationType == 3 || ds.Tables[0].Rows.Count != 0)
                { //修改
                    oCN.RunProc("update Sc_PPBomBillMain  set " +
                                "HRemark='" + HRemark + "', HChecker='" + HMaker + "', HCheckDate=getdate()" +
                                ",HDeptID=" + HDeptID + " where HInterID=" + HInterID);
                    //删除子表
                    oCN.RunProc("delete from Sc_PPBomBillSub where HInterID='" + HInterID + "'");
                }
                //保存子表
                objJsonResult = AddBillSub(msg3, HInterID, OperationType);
                if (objJsonResult.code == "0")
                {
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = objJsonResult.Message;
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                objJsonResult.code = "1";
                objJsonResult.count = 1;
                objJsonResult.Message = null;
                objJsonResult.data = null;
                return objJsonResult;
            }
            catch (Exception e)
            {
                objJsonResult.code = "0";
                objJsonResult.count = 0;
                objJsonResult.Message = "Exception!" + e.ToString();
                objJsonResult.data = null;
                return objJsonResult;
            }
        }
        public json AddBillSub(string msg3, long HInterID, int OperationType)
        {
            List<ClsSc_PPBomBillSub> DetailColl = Newtonsoft.Json.JsonConvert.DeserializeObject<List<ClsSc_PPBomBillSub>>(msg3);
            List<ClsSc_PPBomBillSub> DetailColl2 = Newtonsoft.Json.JsonConvert.DeserializeObject<List<ClsSc_PPBomBillSub>>(msg3);
            DateTime dt = DateTime.Now;
            long HQtyMust = DetailColl2[0].HQtyMust == null ? 0 : DetailColl2[0].HQtyMust; //应发数量
            double HNumerator = DetailColl2[0].HNumerator == null ? 0 : DetailColl2[0].HNumerator;  //分子
            double HDenominator = DetailColl2[0].HDenominator == null ? 0 : DetailColl2[0].HDenominator;  //分母
            double HQtyScrap = DetailColl2[0].HQtyScrap == null ? 0 : DetailColl2[0].HQtyScrap;  //损耗率
            DateTime HSendDate = DetailColl2[0].HSendDate == null ? dt : DetailColl2[0].HSendDate;  //发料日期
            long HBomInterID = DetailColl2[0].HBomInterID == null ? 0 : DetailColl2[0].HBomInterID; //BOM
            long HProcID = DetailColl2[0].HProcID == null ? 0 : DetailColl2[0].HProcID;      //工序内码
            long HKeyMaterID_Line = DetailColl2[0].HKeyMaterID_Line == null ? 0 : DetailColl2[0].HKeyMaterID_Line;  //关键件绑定标记
            long HKeyMaterID_InStock = DetailColl2[0].HKeyMaterID_InStock == null ? 0 : DetailColl2[0].HKeyMaterID_InStock;     //关键件入库标记
            long HKeyMaterID_Ready = DetailColl2[0].HKeyMaterID_Ready == null ? 0 : DetailColl2[0].HKeyMaterID_Ready;  //关键件齐套标记
            long HICMOInterID = DetailColl2[0].HICMOInterID == null ? 0 : DetailColl2[0].HICMOInterID;   //任务单ID
            string HICMOBillNo = DetailColl2[0].HICMOBillNo == null ? "''" : DetailColl2[0].HICMOBillNo;  //任务单号
            string HSeOrderBillNo = DetailColl2[0].HSeOrderBillNo == null ? "''" : DetailColl2[0].HSeOrderBillNo;  //(销售订单号)
            long HSeOrderInterID = DetailColl2[0].HSeOrderInterID == null ? 0 : DetailColl2[0].HSeOrderInterID;    //(销售订单主内码)
            long HSeOrderEntryID = DetailColl2[0].HSeOrderEntryID == null ? 0 : DetailColl2[0].HSeOrderEntryID;     //(销售订单子内码)
            long HChangeTimes = DetailColl2[0].HChangeTimes == null ? 0 : DetailColl2[0].HChangeTimes;         //变更次数
            long HProcessID = DetailColl2[0].HProcessID == null ? 0 : DetailColl2[0].HProcessID; //作业,
            long HICMOENTRYSEQ = DetailColl2[0].HICMOENTRYSEQ == null ? 0 : DetailColl2[0].HICMOENTRYSEQ;//生产订单行号,
            long HICMOEntryID = DetailColl2[0].HICMOEntryID == null ? 0 : DetailColl2[0].HICMOEntryID;//生产订单子内码
            string HPROJECTNO = DetailColl2[0].HPROJECTNO == null ? "''" : DetailColl2[0].HPROJECTNO;  //项目编号,
            long HOPERID = DetailColl2[0].HOPERID == null ? 0 : DetailColl2[0].HOPERID;//金蝶工序,
            long HSEQ = DetailColl2[0].HSEQ == null ? 0 : DetailColl2[0].HSEQ;//行号,
            long HSTOCKSTATUSID = DetailColl2[0].HSTOCKSTATUSID == null ? 0 : DetailColl2[0].HSTOCKSTATUSID; //库存状态,
            long HLOT = DetailColl2[0].HLOT == null ? 0 : DetailColl2[0].HLOT; //批次内码,
            long HOPTQUEUE = DetailColl2[0].HOPTQUEUE == null ? 0 : DetailColl2[0].HOPTQUEUE;//工序序列,
            long HRESERVETYPE = DetailColl2[0].HRESERVETYPE == null ? 0 : DetailColl2[0].HRESERVETYPE;//预留类型,
            double HSelPickedQty = DetailColl2[0].HSelPickedQty == null ? 0 : DetailColl2[0].HSelPickedQty; //领料选单数量,
            double HSELPRCDRETURNQTY = DetailColl2[0].HSELPRCDRETURNQTY == null ? 0 : DetailColl2[0].HSELPRCDRETURNQTY;  //退料选单数量,
            string HCloseMan = DetailColl2[0].HCloseMan == null ? "''" : DetailColl2[0].HCloseMan; //行关闭(默认为'')
            DateTime HEntryCloseDate = DetailColl2[0].HEntryCloseDate == null ? dt : DetailColl2[0].HEntryCloseDate;    //行关闭(默认为'')
            long HCloseType = DetailColl2[0].HCloseType == null ? 0 : DetailColl2[0].HCloseType; //关闭类型(默认为0)
            long HSourceInterID = DetailColl2[0].HSourceInterID == null ? 0 : DetailColl2[0].HSourceInterID;     //源单ID
            long HSourceEntryID = DetailColl2[0].HSourceEntryID == null ? 0 : DetailColl2[0].HSourceEntryID; //源单子ID
            string HSourceBillNo = DetailColl2[0].HSourceBillNo == null ? "''" : DetailColl2[0].HSourceBillNo; //源单单号
            string HSourceBillType = DetailColl2[0].HSourceBillType == null ? "''" : DetailColl2[0].HSourceBillType; //源单类型
            double HRelationQty = DetailColl2[0].HRelationQty == null ? 0 : DetailColl2[0].HRelationQty;     //关联数量
            double HRelationMoney = DetailColl2[0].HRelationMoney == null ? 0 : DetailColl2[0].HRelationMoney; //关联金额
            long HCHILDSUPPLYORGID = DetailColl2[0].HCHILDSUPPLYORGID == null ? 0 : DetailColl2[0].HCHILDSUPPLYORGID;
            long HSUPPLYORGID = DetailColl2[0].HSUPPLYORGID == null ? 0 : DetailColl2[0].HSUPPLYORGID;
            long HENTRUSTPICKORGID = DetailColl2[0].HENTRUSTPICKORGID == null ? 0 : DetailColl2[0].HENTRUSTPICKORGID;
            long HSRCTRANSORGID = DetailColl2[0].HSRCTRANSORGID == null ? 0 : DetailColl2[0].HSRCTRANSORGID;
            long HGROUPBYOWNERID = DetailColl2[0].HGROUPBYOWNERID == null ? 0 : DetailColl2[0].HGROUPBYOWNERID;
            long HOWNERID = DetailColl2[0].HOWNERID == null ? 0 : DetailColl2[0].HOWNERID;
            long HAuxPropID = DetailColl2[0].HAuxPropID == null ? 0 : DetailColl2[0].HAuxPropID;
            long HERPInterID = DetailColl2[0].HERPInterID == null ? 0 : DetailColl2[0].HERPInterID;
            long HERPEntryID = DetailColl2[0].HERPEntryID == null ? 0 : DetailColl2[0].HERPEntryID;
            double HMoveStockQty = DetailColl2[0].HMoveStockQty == null ? 0 : DetailColl2[0].HMoveStockQty;
            double HBackRelationQty = DetailColl2[0].HBackRelationQty == null ? 0 : DetailColl2[0].HBackRelationQty;
            string HOWNERTYPEID = DetailColl2[0].HOWNERTYPEID == null ? "''" : DetailColl2[0].HOWNERTYPEID;
            string HBatchNO = DetailColl2[0].HBatchNO == null ? "''" : DetailColl2[0].HBatchNO;
            string HMTONo = DetailColl2[0].HMTONo == null ? "''" : DetailColl2[0].HMTONo;
            string HRemark = DetailColl2[0].HRemark == null ? "''" : DetailColl2[0].HRemark;
            string HMaterNumber = DetailColl2[0].HMaterNumber == null ? "''" : DetailColl2[0].HMaterNumber;
            string HUnitNumber = DetailColl2[0].HUnitNumber == null ? "''" : DetailColl2[0].HUnitNumber;
            int i = 0;
            foreach (ClsSc_PPBomBillSub oSub in DetailColl)
            {
                i++;
                if (oSub.HQty <= 0 || oSub.HQty == null)
                {
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = "第" + i + "行,数量不能为0或者小于0";
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                if (oSub.HMaterID == 0)
                {
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = "第" + i + "行,物料不能为空";
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                //if (oSub.HSourceID == 0)
                //{
                //    objJsonResult.code = "0";
                //    objJsonResult.count = 0;
                //    objJsonResult.Message = "第" + i + "行,生产资源不能为空";
                //    objJsonResult.data = null;
                //    return objJsonResult;
                //}
                if (oSub.HUnitID == 0)
                {
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = "第" + i + "行,计量单位不能为空";
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                DataSet Cs;
                Int64 NewHEntryID = 1;
                Cs = oCN.RunProcReturn("select MAX(HEntryID)HEntryID from Sc_PPBomBillSub", "Sc_PPBomBillSub");
                if (Cs.Tables[0].Rows.Count != 0 && ClsPub.isLong(Cs.Tables[0].Rows[0]["HEntryID"].ToString()) != 0)
                {
                    NewHEntryID = ClsPub.isLong(Cs.Tables[0].Rows[0]["HEntryID"].ToString());
                    NewHEntryID += 1;
                }
                oCN.RunProc($@"Insert into Sc_PPBomBillSub
                (HInterID,HEntryID,HMaterID,HMaterNumber,HUnitID,HUnitNumber,HSPID,HQty,HQtyMust,HWHID,HRemark
                ,HSourceInterID,HSourceEntryID,HSourceBillNo,HSourceBillType,HICMOInterID,HICMOEntryID,HICMOBillNo
                ,HCHILDSUPPLYORGID,HSUPPLYORGID,HENTRUSTPICKORGID,HSRCTRANSORGID,HGROUPBYOWNERID,HOWNERID,HOWNERTYPEID
                ,HRelationQty,HMoveStockQty,HAuxPropID,HBatchNO,HMTONo,HQtyScrap,HERPInterID,HERPEntryID
                ,HBackRelationQty,HNumerator,HDenominator,HBASEUNITID,HProcessID,HICMOENTRYSEQ,HPROJECTNO
                ,HOPERID,HSEQ,HSTOCKSTATUSID,HLOT,HOPTQUEUE,HRESERVETYPE,HSelPickedQty,HSELPRCDRETURNQTY)
                 values({HInterID},{NewHEntryID},{oSub.HMaterID},'{HMaterNumber}',{oSub.HUnitID},'{HUnitNumber}',{oSub.HSPID},{(oSub.HQty == null ? 0 : oSub.HQty)}
                ,{HQtyMust},{oSub.HWHID},'{HRemark}',{HSourceInterID},{HSourceEntryID},{HSourceBillNo},{HSourceBillType},{HICMOInterID},{HICMOEntryID},{HICMOBillNo},{HCHILDSUPPLYORGID},{HSUPPLYORGID},{HENTRUSTPICKORGID},{HSRCTRANSORGID},{HGROUPBYOWNERID},{HOWNERID},{HOWNERTYPEID},{HRelationQty},{HMoveStockQty},{HAuxPropID},{HBatchNO},{HMTONo},{HQtyScrap},{HERPInterID},
                  {HERPEntryID},{HBackRelationQty},{HNumerator},{HDenominator},{oSub.HBASEUNITID},{HProcessID},{HICMOENTRYSEQ},{HPROJECTNO},{HOPERID},{HSEQ},{HSTOCKSTATUSID},{HLOT},{HOPTQUEUE},{HRESERVETYPE},{HSelPickedQty},{HSELPRCDRETURNQTY})");
            }
            objJsonResult.code = "1";
            objJsonResult.count = 1;
            objJsonResult.Message = null;
            objJsonResult.data = null;
            return objJsonResult;
        }
        #endregion
        /// <summary>
        ///删除功能
        /// </summary>
        /// <returns></returns>
        [Route("Sc_PPBomBill/DeltetPPBomBillBill")]
        [HttpGet]
        public object DeltetSeOrderBill(string HInterID)
        {
            try
            {
                oCN.BeginTran();
                oCN.RunProc("Delete From Sc_PPBomBillMain where HInterID = " + HInterID);
                oCN.RunProc("Delete From Sc_PPBomBillSub where HInterID = " + HInterID);
                oCN.Commit();
                objJsonResult.code = "1";
                objJsonResult.count = 1;
                objJsonResult.Message = "删除成功!";
                objJsonResult.data = null;
                return objJsonResult;
            }
            catch (Exception e)
            {
                oCN.RollBack();
                objJsonResult.code = "0";
                objJsonResult.count = 0;
                objJsonResult.Message = "Exception!" + e.ToString();
                objJsonResult.data = null;
                return objJsonResult;
            }
        }
    }
}