duhe
2025-04-15 d03c33eeebd11111ee6c116b35ccf8cd7372de8d
WebAPI/Controllers/SCGL/Sc_PPBomBillController.cs
@@ -1,4 +1,5 @@
using Model.生产管理;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
using Pub_Class;
using System;
@@ -14,6 +15,8 @@
    //生产用料Controller
    public class Sc_PPBomBillController : ApiController
    {
        //获取系统参数
        Pub_Class.ClsXt_SystemParameter oSystemParameter = new Pub_Class.ClsXt_SystemParameter();
        public DBUtility.ClsPub.Enum_BillStatus BillStatus;
        private json objJsonResult = new json();
@@ -32,6 +35,7 @@
        {
            try
            {
                List<object> a = new List<object>();
                //判断是否有查询权限
                if (!DBUtility.ClsPub.Security_Log("Sc_PPBomBillList_Query", 1, false, user))
                {
@@ -52,6 +56,12 @@
                    string sql = sql1 + sWhere + " order by hmainid desc ";
                    ds = oCN.RunProcReturn(sql, "h_v_IF_PPBomBillList");
                }
                foreach (DataColumn col in ds.Tables[0].Columns)//遍历ds中第一个表(Tables[0])的所有列(Columns)每次循环中,col变量会持有当前列的引用
                {
                    Type dataType = col.DataType; //获取当前数据类型传入 自定义变量datadataType
                    string ColmString = "{\"ColmCols\":\"" + col.ColumnName + "\",\"ColmType\":\"" + dataType.Name + "\"}"; //字符串拼接         // 将列名和数据类型信息拼接成一个JSON格式的字符串
                    a.Add(JsonConvert.DeserializeObject(ColmString));//获取到DataColumn列对象的列名
                }
                //if (ds.Tables[0].Rows.Count != 0 || ds != null)
                //{
@@ -59,6 +69,7 @@
                objJsonResult.count = 1;
                objJsonResult.Message = "Sucess!";
                objJsonResult.data = ds.Tables[0];
                objJsonResult.list = a;
                return objJsonResult;
                //}
                //else
@@ -79,6 +90,104 @@
                return objJsonResult;
            }
        }
        [Route("Sc_PPBomBill/Editlist")]
        [HttpGet]
        public object Editlist(string sWhere)
        {
            try
            {
                List<object> a = new List<object>();
                //判断是否有查询权限
                if (sWhere == null || sWhere.Equals(""))
                {
                    ds = oCN.RunProcReturn("select * from h_v_IF_PPBomBillList order by hmainid desc ", "h_v_IF_PPBomBillList");
                }
                else
                {
                    string sql1 = "select * from h_v_IF_PPBomBillList where 1 = 1 ";
                    string sql = sql1 + sWhere + " order by hmainid desc ";
                    ds = oCN.RunProcReturn(sql, "h_v_IF_PPBomBillList");
                }
                foreach (DataColumn col in ds.Tables[0].Columns)//遍历ds中第一个表(Tables[0])的所有列(Columns)每次循环中,col变量会持有当前列的引用
                {
                    Type dataType = col.DataType; //获取当前数据类型传入 自定义变量datadataType
                    string ColmString = "{\"ColmCols\":\"" + col.ColumnName + "\",\"ColmType\":\"" + dataType.Name + "\"}"; //字符串拼接         // 将列名和数据类型信息拼接成一个JSON格式的字符串
                    a.Add(JsonConvert.DeserializeObject(ColmString));//获取到DataColumn列对象的列名
                }
                objJsonResult.code = "1";
                objJsonResult.count = 1;
                objJsonResult.Message = "Sucess!";
                objJsonResult.data = ds.Tables[0];
                objJsonResult.list = a;
                return objJsonResult;
            }
            catch (Exception e)
            {
                objJsonResult.code = "0";
                objJsonResult.count = 0;
                objJsonResult.Message = "Exception!" + e.ToString();
                objJsonResult.data = null;
                return objJsonResult;
            }
        }
        #region 生产用料清单列表分页列表
        [Route("Sc_PPBomBill/page")]
        [HttpGet]
        public object page(string sWhere, string user,int page,int size)
        {
            try
            {
                List<object> columnNameList = new List<object>();
                //编辑权限
                if (!DBUtility.ClsPub.Security_Log_second("Sc_PPBomBillList_Query", 1, false, user))
                {
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = "无查看权限!";
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                if (sWhere == null || sWhere.Equals(""))
                {
                    ds = oCN.RunProcReturn("exec h_p_Sc_PPBomBillList " + page + "," + size + "," + "''", "h_p_Sc_PPBomBillList");
                }
                else
                {
                    ds = oCN.RunProcReturn("exec h_p_Sc_PPBomBillList " + page + "," + size + ",'"  + sWhere + "'", "h_p_Sc_PPBomBillList");
                }
                //添加列名
                foreach (DataColumn col in ds.Tables[0].Columns)
                {
                    Type dataType = col.DataType;
                    string ColmString = "{\"ColmCols\":\"" + col.ColumnName + "\",\"ColmType\":\"" + dataType.Name + "\"}";
                    columnNameList.Add(JsonConvert.DeserializeObject(ColmString));//获取到DataColumn列对象的列名
                }
                objJsonResult.code = "1";
                objJsonResult.count = int.Parse(ds.Tables[1].Rows[0]["count"].ToString());
                objJsonResult.Message = "Sucess!";
                objJsonResult.list = columnNameList;
                objJsonResult.data = ds.Tables[0];
                return objJsonResult;
            }
            catch (Exception e)
            {
                objJsonResult.code = "0";
                objJsonResult.count = 0;
                objJsonResult.Message = "Exception!" + e.ToString();
                objJsonResult.data = null;
                return objJsonResult;
            }
        }
        #endregion
        #region 生产用料清单 审核/反审核
        [Route("Sc_PPBomBill/DeOrAuditBill")]
        [HttpGet]
@@ -237,6 +346,216 @@
                throw (e);
            }
        }
        #endregion
        #region 生产用料单 保存/编辑功能 新方法
        [Route("Sc_PPBomBill/sc_PPBomBillAdd")]
        [HttpPost]
        public object sc_PPBomBillAdd([FromBody] JObject sMainSub)
        {
            var _value = sMainSub["sMainSub"].ToString();
            string msg1 = _value.ToString();
            string[] sArray = msg1.Split(new string[] { ";" }, StringSplitOptions.RemoveEmptyEntries);
            try
            {
                string msg2 = sArray[0].ToString(); //主表数据
                string msg3 = sArray[1].ToString(); //子表数据
                int OperationType = int.Parse(sArray[2].ToString()); // 数据类型 1添加 3修改
                string user = sArray[3].ToString();
                //判断是否有编辑权限
                if (!DBUtility.ClsPub.Security_Log("QC_TestSampleCheckBill_Edit", 1, false, user))
                {
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = "无编辑权限!";
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                ClsSc_PPBomBillMain list = Newtonsoft.Json.JsonConvert.DeserializeObject<ClsSc_PPBomBillMain>(msg2);
                string BillType = "3720";
                string HBillSubType = "3720";
                long HInterID = list.HInterID;//递入type得到的单据ID
                string HBillNo = list.HBillNo;//递入type得到的单据号
                int HBillStatus = 1;
                string HMaker = user;//制单人
                int HYear = DateTime.Now.Year;
                double HPeriod = DateTime.Now.Month;
                long HICMOInterID = list.HICMOInterID;//任务单ID
                long HICMOEntryID = list.HICMOEntryID;//任务单ID
                string HICMOBillNo = list.HICMOBillNo;//任务单ID
                long HMaterID = list.HMaterID;//产品ID
                long HUnitID = list.HUnitID;//计量单位
                long HPRDORGID = list.HPRDORGID;//组织ID
                long HICMOEntrySEQ = list.HICMOEntrySEQ;
                DateTime HDate = list.HDate;
                double HQty = list.HQty;
                long HDeptID = list.HDeptID;
                string HRemark = list.HRemark;
                string HChecker = "";
                string HCheckDate = "";
                string HSeOrderBillNo = "";
                long HSeOrderInterID = 0;
                long HSeOrderEntryID = 0;
                long HENTRUSTORGID = 0;
                long HPARENTOWNERID = 0;
                long HPARENTOWNERTYPEID = 0;
                long HERPInterID = 0;
                long HSeOrderEntrySEQ = 0;
                string HERPBillType = "";
                string HREQSRC = "";
                oCN.BeginTran();
                if (OperationType== 1)
                {
                    ds = oCN.RunProcReturn("select * from Sc_PPBomBillMain where HBillNo='" + HBillNo + "'", "Sc_PPBomBillMain");
                    if (ds.Tables[0].Rows.Count == 1)
                    {
                        oCN.RollBack();
                        objJsonResult.code = "0";
                        objJsonResult.count = 0;
                        objJsonResult.Message = "单据号重复!";
                        objJsonResult.data = null;
                        return objJsonResult;
                    }
                    //主表
                    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,HREQSRC,HRemark)
                        values(" + HInterID + "," + DateTime.Now.Year + "," + DateTime.Now.Month + ",'" + BillType + "','" +
                    HBillSubType + "','" + HDate + "','" + HBillNo + "','" + HBillStatus + "'," + HICMOInterID +
                    "," + HICMOEntryID + ",'" + HMaterID + "'," + HUnitID + "," + HQty + "," + HDeptID +
                    ",'" + HMaker + "',getdate(),'" + HChecker + "','" + HCheckDate + "','" + HSeOrderBillNo + "'," + HSeOrderInterID + "," + HSeOrderEntryID + "," + HPRDORGID + "," + HENTRUSTORGID + "," + HPARENTOWNERID + "," +
                    HPARENTOWNERTYPEID + "," + HERPInterID + ",'" + HERPBillType + "'," + HSeOrderEntrySEQ + "," + HICMOEntrySEQ + ",'" + HREQSRC + "','"+ HRemark + "')");
                }
                else  if (OperationType == 3 )
                { //修改
                    oCN.RunProc("update Sc_PPBomBillMain  set " +
                                "HRemark='" + HRemark + "', HChecker='" + HMaker + "', HCheckDate=getdate()" +
                                ",HDeptID=" + HDeptID + ",HICMOInterID=" + HICMOInterID + ",HICMOEntryID=" + HICMOEntryID + ",HMaterID=" + HMaterID + ",HUnitID=" + HUnitID + ",HICMOEntrySEQ=" + HICMOEntrySEQ + " ,HQty=" + HQty + " where HInterID=" + HInterID);
                    //删除子表
                    oCN.RunProc("delete from Sc_PPBomBillSub where HInterID='" + HInterID + "'");
                }
                else
                {
                    oCN.RollBack();
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = "操作类型无效!";
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                List<ClsSc_PPBomBillSub> DetailColl = Newtonsoft.Json.JsonConvert.DeserializeObject<List<ClsSc_PPBomBillSub>>(msg3);
                int i = 0;
                foreach (ClsSc_PPBomBillSub oSub in DetailColl)
                {
                    i++;
                    string HMaterNumber = oSub.HMaterNumber;
                    string HUnitNumber = oSub.HUnitNumber;
                    long HQtyMust = 0;
                    long HSourceInterID = oSub.HSourceInterID;
                    long HSourceEntryID = oSub.HSourceEntryID;
                    long HCHILDSUPPLYORGID = oSub.HCHILDSUPPLYORGID;
                    long HSUPPLYORGID = oSub.HSUPPLYORGID;
                    long HENTRUSTPICKORGID = oSub.HENTRUSTPICKORGID;
                    long HSRCTRANSORGID = oSub.HSRCTRANSORGID;
                    long HGROUPBYOWNERID = oSub.HGROUPBYOWNERID;
                    long HOWNERID = oSub.HOWNERID;
                    long HAuxPropID = oSub.HAuxPropID;
                    long HERPEntryID = oSub.HERPEntryID;
                    long HProcessID = oSub.HProcessID;
                    long HICMOENTRYSEQ = oSub.HICMOENTRYSEQ;
                    long HOPERID = oSub.HOPERID;
                    long HSEQ = i;
                    long HSTOCKSTATUSID = oSub.HSTOCKSTATUSID;
                    long HOPTQUEUE = oSub.HOPTQUEUE;
                    long HLOT = oSub.HLOT;
                    long HRESERVETYPE = oSub.HRESERVETYPE;
                    string HOWNERTYPEID = oSub.HOWNERTYPEID;
                    double HRelationQty = oSub.HRelationQty;
                    double HMoveStockQty = oSub.HMoveStockQty;
                    double HQtyScrap = oSub.HQtyScrap;
                    double HBackRelationQty = oSub.HBackRelationQty;
                    double HNumerator = oSub.HNumerator;
                    double HDenominator = oSub.HDenominator;
                    double HSelPickedQty = oSub.HSelPickedQty;
                    double HSELPRCDRETURNQTY = oSub.HSELPRCDRETURNQTY;
                    string HSourceBillNo = oSub.HSourceBillNo;
                    string HSourceBillType = oSub.HSourceBillType;
                    string HBatchNO = oSub.HBatchNO;
                    string HMTONo = oSub.HMTONo;
                    string HPROJECTNO = oSub.HPROJECTNO;
                    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.HUnitID == 0)
                    {
                        objJsonResult.code = "0";
                        objJsonResult.count = 0;
                        objJsonResult.Message = "第" + i + "行,计量单位不能为空";
                        objJsonResult.data = null;
                        return objJsonResult;
                    }
                    Int64 NewHEntryID = i;
                    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},'{oSub.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})");
                }
                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;
            }
        }
        #endregion
        #region 生产用料单 保存/编辑功能
@@ -627,5 +946,278 @@
            }
        }
        #region [同步单据]
        [Route("Sc_PPBomBill/Sc_PPBomBillViewApi")]
        [HttpGet]
        public json Sc_PPBomBillViewApi(string BillNo, string BillType)
        {
            string sql = string.Empty;
            string sReturn = "";
            if (oSystemParameter.ShowBill(ref sReturn) == true)
            {
                //系统参数是否为私有云模式,N为公有云模式,Y为私有云模式
                if (oSystemParameter.omodel.WMS_CloudMode == "Y")
                {
                    #region [私有云模式,直接调用数据库存储过程更新]
                    try
                    {
                        oCN.BeginTran();
                        SQLHelper.ClsCN oCn = new SQLHelper.ClsCN();
                        DataSet DS = oCn.RunProcReturn("exec h_p_WMS_ERPSourceBillToLocal '" + BillNo + "','" + BillType + "'", "h_p_WMS_ERPSourceBillToLocal");
                        if (DS == null)
                        {
                            objJsonResult.code = "0";
                            objJsonResult.count = 0;
                            objJsonResult.Message = "单据同步失败";
                            objJsonResult.data = null;
                            return objJsonResult;
                        }
                        else
                        {
                            if (DBUtility.ClsPub.isStrNull(DS.Tables[0].Rows[0]["HBack"]) == "2")
                            {
                                objJsonResult.code = "0";
                                objJsonResult.count = 0;
                                objJsonResult.Message = "ERP中不存在该单据号";
                                objJsonResult.data = null;
                                return objJsonResult;
                            }
                            else
                            {
                                objJsonResult.code = "1";
                                objJsonResult.count = 1;
                                objJsonResult.Message = "单据同步成功";
                                objJsonResult.data = null;
                                return objJsonResult;
                            }
                        }
                    }
                    catch (Exception e)
                    {
                        objJsonResult.code = "0";
                        objJsonResult.count = 0;
                        objJsonResult.Message = "Exception!" + e.ToString();
                        objJsonResult.data = null;
                        return objJsonResult;
                    }
                    #endregion
                }
                else
                {
                    #region [公有云模式,调用WEBAPI的方式进行更新]
                    var json = new
                    {
                        CreateOrgId = 0,
                        Number = BillNo,
                        Id = ""
                    };
                    #region [金蝶部分]
                    //登录金蝶
                    var loginRet = InvokeHelper.Login();
                    var isSuccess = JObject.Parse(loginRet)["LoginResultType"].Value<int>();
                    //判断是否登录成功
                    if (isSuccess < 0)
                    {
                        objJsonResult.code = "0";
                        objJsonResult.count = 0;
                        objJsonResult.Message = loginRet;
                        objJsonResult.data = null;
                        return objJsonResult;
                    }
                    //查看 获取数据
                    var _result = InvokeHelper.View("PRD_PPBOM", JsonConvert.SerializeObject(json));
                    var _saveObj = JObject.Parse(_result);
                    //判断数据是否获取成功
                    if (_saveObj["Result"]["ResponseStatus"]["IsSuccess"].ToString().ToUpper() != "TRUE")
                    {
                        objJsonResult.code = "0";
                        objJsonResult.count = 0;
                        objJsonResult.Message = "金蝶生产用料单同步失败jsonRoot:" + _result;
                        objJsonResult.data = null;
                        return objJsonResult;
                    }
                    #endregion
                    //获取主表数据
                    DataSet Ds;
                    Int64 InterID = 0;
                    Ds = oCN.RunProcReturn("select * from Sc_PPBomBillMain where HBillNo = '" + BillNo + "'", "Sc_PPBomBillMain");
                    if (Ds.Tables[0].Rows.Count != 0 && ClsPub.isLong(Ds.Tables[0].Rows[0]["HInterID"].ToString()) != 0)
                    {
                        InterID = ClsPub.isLong(Ds.Tables[0].Rows[0]["HInterID"].ToString());
                    }
                    #region [主表数据赋值]
                    var jsonData = new
                    {
                        HInterID = _saveObj["Result"]["Result"]["Id"],
                        HYear = DateTime.Now.Year,
                        HPeriod = DateTime.Now.Month,
                        HBillType = 3720,
                        HBillSubType = 3720,
                        HDate = _saveObj["Result"]["Result"]["CreateDate"],
                        HBillNo = _saveObj["Result"]["Result"]["BillNo"],
                        HBillStatus         = _saveObj["Result"]["Result"]["ApproverId_Id"].ToString() == Convert.ToString(0) ? 1 : 2,
                        HICMOInterID        = _saveObj["Result"]["Result"]["MoId"],
                        HICMOEntryID        = _saveObj["Result"]["Result"]["MOEntryID"],
                        HMaterID            = _saveObj["Result"]["Result"]["MaterialID_Id"],
                        HUnitID             = _saveObj["Result"]["Result"]["UnitID_Id"],
                        HQty                = _saveObj["Result"]["Result"]["Qty"],
                        HDeptID             = _saveObj["Result"]["Result"]["WorkshopID_Id"],
                        HMaker              = _saveObj["Result"]["Result"]["CreatorId"]["Name"],
                        HMakeDate           = _saveObj["Result"]["Result"]["CreateDate"],
                        HChecker            = _saveObj["Result"]["Result"]["ApproverId"]["Name"],
                        HCheckDate          = _saveObj["Result"]["Result"]["ApproveDate"],
                        HSeOrderBillNo      = _saveObj["Result"]["Result"]["SALEORDERNO"],
                        HSeOrderInterID     = _saveObj["Result"]["Result"]["SaleOrderId"],
                        HSeOrderEntryID     = _saveObj["Result"]["Result"]["SaleOrderEntryId"],
                        HPRDORGID           = _saveObj["Result"]["Result"]["PrdOrgId_Id"],
                        HENTRUSTORGID       = _saveObj["Result"]["Result"]["EntrustOrgId_Id"],
                        HPARENTOWNERID      = _saveObj["Result"]["Result"]["ParentOwnerId_Id"],
                        HPARENTOWNERTYPEID  = _saveObj["Result"]["Result"]["ParentOwnerTypeId"],
                        HREQSRC             = _saveObj["Result"]["Result"]["ReqSrc"],
                        HERPInterID = _saveObj["Result"]["Result"]["Id"],
                        HERPBillType              = "PPBOM",
                        HSeOrderEntrySEQ          = _saveObj["Result"]["Result"]["SaleOrderEntrySeq"],
                        HICMOEntrySEQ = _saveObj["Result"]["Result"]["MOEntrySeq"]
                    };
                    #endregion
                    // 删除主表对应数据
                    sql = $"delete from Sc_PPBomBillMain where HInterID = " + InterID;
                    oCN.RunProc(sql);
                    //插入主表
                    sql = $@"
                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,HREQSRC
               ,HERPInterID,HERPBillType,HSeOrderEntrySEQ,HICMOEntrySEQ
                 )
                values
                ({jsonData.HInterID},{jsonData.HYear},{jsonData.HPeriod},{jsonData.HBillType},{jsonData.HBillSubType},
                '{jsonData.HDate}','{jsonData.HBillNo}',{jsonData.HBillStatus},{jsonData.HICMOInterID},{jsonData.HICMOEntryID},
                {jsonData.HMaterID},{jsonData.HUnitID},{jsonData.HQty},{jsonData.HDeptID},'{jsonData.HMaker}','{jsonData.HMakeDate}','{jsonData.HChecker}',
                '{jsonData.HCheckDate}','{jsonData.HSeOrderBillNo}',{jsonData.HSeOrderInterID},{jsonData.HSeOrderEntryID},{jsonData.HPRDORGID},
                {jsonData.HENTRUSTORGID},{jsonData.HPARENTOWNERID},'{jsonData.HPARENTOWNERTYPEID}','{jsonData.HREQSRC}',{jsonData.HERPInterID},
                '{jsonData.HERPBillType}',{jsonData.HSeOrderEntrySEQ},'{jsonData.HICMOEntrySEQ}')";
                    oCN.RunProc(sql);
                    #region [申请子表变量]
                    var dataArr = _saveObj["Result"]["Result"]["PPBomEntry"];
                    DataSet Cs;
                    double RelationQty = 0;
                    #endregion
                    int i = 0;
                    // 获取子表数据
                    Cs = oCN.RunProcReturn("select * from Sc_PPBomBillSub where HInterID = " + InterID, "Sc_PPBomBillSub");
                    // 删除子表对应数据
                    sql = $"delete from Sc_PPBomBillSub where HInterID = " + InterID;
                    oCN.RunProc(sql);
                    foreach (var oSub in dataArr)
                    {
                        #region [子表数据赋值]
                        if (Cs.Tables[0].Rows.Count != 0 && ClsPub.isLong(Cs.Tables[0].Rows[0]["HInterID"].ToString()) != 0)
                        {
                            RelationQty = ClsPub.isDoule(Cs.Tables[0].Rows[i]["HRelationQty"].ToString());
                            i++;
                        }
                        var subData = new
                        {
                            HInterID = _saveObj["Result"]["Result"]["Id"],
                            HEntryID = oSub["Id"],
                            HMaterID = oSub["MaterialID_Id"],
                            HUnitID           = oSub["UnitID_Id"],
                            HQty              = oSub["NeedQty"],
                            HQtyMust          = oSub["NeedQty"],
                            HWHID             = oSub["StockID_Id"],
                            HRemark           = "CLOUD导入",
                            HSourceInterID    = oSub["MoId"],
                            HSourceEntryID    = oSub["MoEntryId"],
                            HSourceBillNo     = oSub["MoBillNo"],
                            HSourceBillType   = 3710,
                            HICMOInterID      = oSub["MoId"],
                            HICMOEntryID      = oSub["MoEntryId"],
                            HICMOBillNo       = oSub["MoBillNo"],
                            HCHILDSUPPLYORGID = oSub["ChildSupplyOrgId_Id"],
                            HSUPPLYORGID      = oSub["SupplyOrg_Id"],
                            HENTRUSTPICKORGID = oSub["EntrustPickOrgId_Id"],
                            HSRCTRANSORGID    = oSub["SrcTransOrgId_Id"],
                            HGROUPBYOWNERID   = oSub["GroupByOwnerId_Id"],
                            HOWNERID          = oSub["OwnerID_Id"],
                            HOWNERTYPEID      = oSub["OwnerTypeId"],
                            HRelationQty      = Convert.ToInt32(oSub["SelPickedQty"]) - Convert.ToInt32(oSub["SelPrcdReturnQty"]),
                            HMoveStockQty     = oSub["SelTranslateQty"],
                            HAuxPropID        = oSub["AuxPropID_Id"],
                            HBatchNO          = oSub["Lot_Text"],
                            HMTONo            = oSub["MTONO"],
                            HQtyScrap               = Convert.ToInt32(oSub["BaseNumerator"]) / Convert.ToInt32(oSub["BaseDenominator"]),
                            HERPInterID             = _saveObj["Result"]["Result"]["Id"],
                            HERPEntryID             = oSub["Id"],
                            HBackRelationQty        = oSub["WipQty"],
                            HNumerator              = oSub["Numerator"],
                            HDenominator             = oSub["Denominator"],
                            HBASEUNITID             = oSub["BaseUnitID_Id"],
                            HProcessID              = oSub["ProcessID_Id"],
                            HICMOENTRYSEQ           = oSub["MoEntrySeq"],
                            HPROJECTNO              = oSub["ProjectNO"],
                            HOPERID                 = oSub["OperID"],
                            HSEQ                    = oSub["Seq"],
                            HSTOCKSTATUSID          = oSub["StockStatusId_Id"],
                            HLOT                    = oSub["Lot_Id"],
                            HOPTQUEUE               = oSub["OptQueue"],
                            HRESERVETYPE            = oSub["ReserveType"],
                            HSelPickedQty           = oSub["SelPickedQty"],
                            HSELPRCDRETURNQTY = oSub["SelPrcdReturnQty"],
                        };
                        #endregion
                        //插入子表
                        sql = $@"
                 insert into Sc_PPBomBillSub
                 (HInterID,HEntryID,HMaterID,HUnitID,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
                 ({subData.HInterID},{subData.HEntryID},{subData.HMaterID},{subData.HUnitID},{subData.HQty},{subData.HQtyMust},{subData.HWHID},'{subData.HRemark}',{subData.HSourceInterID},{subData.HSourceEntryID},'{subData.HSourceBillNo}','{subData.HSourceBillType}',{subData.HICMOInterID},{subData.HICMOEntryID},'{subData.HICMOBillNo}',{subData.HCHILDSUPPLYORGID},{subData.HSUPPLYORGID},{subData.HENTRUSTPICKORGID},{subData.HSRCTRANSORGID},{subData.HGROUPBYOWNERID},{subData.HOWNERID},'{subData.HOWNERTYPEID}',{subData.HRelationQty},{subData.HMoveStockQty},{subData.HAuxPropID},'{subData.HBatchNO}','{subData.HMTONo}',{subData.HQtyScrap},{subData.HERPInterID},{subData.HERPEntryID},{subData.HBackRelationQty},'{subData.HNumerator}','{subData.HDenominator}',{subData.HBASEUNITID},{subData.HProcessID},{subData.HICMOENTRYSEQ},'{subData.HPROJECTNO}',{subData.HOPERID},{subData.HSEQ},{subData.HSTOCKSTATUSID},{subData.HLOT},{subData.HOPTQUEUE},'{subData.HRESERVETYPE}',{subData.HSelPickedQty},{subData.HSELPRCDRETURNQTY}
                  )";
                        oCN.RunProc(sql);
                    }
                    objJsonResult.code = "1";
                    objJsonResult.count = 1;
                    objJsonResult.Message = "单据同步成功!";
                    objJsonResult.data = null;
                    return objJsonResult;
                    #endregion
                }
            }
            else
            {
                objJsonResult.code = "0";
                objJsonResult.count = 0;
                objJsonResult.Message = "单据读取失败!";
                objJsonResult.data = null;
                return objJsonResult;
            }
        }
        #endregion
    }
}