| | |
| | | using Newtonsoft.Json.Linq; |
| | | using Newtonsoft.Json; |
| | | using Newtonsoft.Json.Linq; |
| | | using Pub_Class; |
| | | using System; |
| | | using System.Collections; |
| | | using System.Collections.Generic; |
| | | using System.Data; |
| | | using System.Data.SqlClient; |
| | | using System.Linq; |
| | | using System.Web.Http; |
| | | using WebAPI.Models; |
| | | |
| | |
| | | { |
| | | try |
| | | { |
| | | List<object> columnNameList = new List<object>(); //定义声明变量 ,把通过 new List<object>()创建的 实例,赋值给变量 |
| | | //判断是否有查询权限 |
| | | //if (!DBUtility.ClsPub.Security_Log("WW_EntrustOrderBillQuery", 1, false, user)) |
| | | //{ |
| | | // objJsonResult.code = "0"; |
| | | // objJsonResult.count = 0; |
| | | // objJsonResult.Message = "无查询权限!"; |
| | | // objJsonResult.data = null; |
| | | // return objJsonResult; |
| | | //} |
| | | |
| | | //string sql1 = "select * from h_v_IF_EntrustOrderBillList where 1 = 1 "; |
| | | //if (sWhere == null || sWhere.Equals("")) |
| | | //{ |
| | | // ds = oCN.RunProcReturn("select * from h_v_IF_EntrustOrderBillList " + sWhere, "h_v_IF_EntrustOrderBillList"); |
| | | // ds = oCN.RunProcReturn(sql1+ " order by hmainid desc", "h_v_IF_EntrustOrderBillList"); |
| | | //} |
| | | //else |
| | | //{ |
| | | // string sql1 = "select * from h_v_IF_EntrustOrderBillList where 1 = 1 "; |
| | | // string sql = sql1 + sWhere; |
| | | // ds = oCN.RunProcReturn(sql, "h_v_IF_EntrustOrderBillList"); |
| | | // ds = oCN.RunProcReturn(sql1+ sWhere+ " order by hmainid desc", "h_v_IF_EntrustOrderBillList"); |
| | | //} |
| | | |
| | | //判断是否有采购经理权限 |
| | | bool isCgjl = Security_Log("WW_EntrustOrderBill_PurchasManager", 1, true, user); |
| | | //判断是否有采购经理权限(安瑞) |
| | | bool isCgjl = Security_Log("WW_EntrustOrderBill_PurchasManager", 1, false, user); |
| | | if (!isCgjl) |
| | | { |
| | | sWhere += $" and HEmpID in (select HEmpID from Gy_Czygl where Czymc='{user}' )"; |
| | | } |
| | | string sql = "select * from h_v_IF_EntrustOrderBillList where 1 = 1 " + sWhere; |
| | | ds = oCN.RunProcReturn(sql, "h_v_IF_EntrustOrderBillList"); |
| | | |
| | | 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格式的字符串 |
| | | columnNameList.Add(JsonConvert.DeserializeObject(ColmString));//获取到DataColumn列对象的列名 |
| | | } |
| | | //if (ds.Tables[0].Rows.Count != 0 || ds != null) |
| | | //{ |
| | | objJsonResult.code = "1"; |
| | | objJsonResult.count = 1; |
| | | objJsonResult.Message = "Sucess!"; |
| | | objJsonResult.data = ds.Tables[0]; |
| | | objJsonResult.list = columnNameList; |
| | | return objJsonResult; |
| | | //} |
| | | //else |
| | | //{ |
| | | //objJsonResult.code = "0"; |
| | | //objJsonResult.count = 0; |
| | | //objJsonResult.Message = "无数据"; |
| | | //objJsonResult.data = null; |
| | | //return objJsonResult; |
| | | //} |
| | | } |
| | | catch (Exception e) |
| | | { |
| | |
| | | } |
| | | } |
| | | |
| | | #region 委外订单 金蝶同步 |
| | | [Route("WW_EntrustOrderBill/SaveWW_EntrustOrderBillListApi")] |
| | | [HttpPost] |
| | | public object SaveWW_EntrustOrderBillListApi([FromBody] JObject sMainSub) |
| | | { |
| | | LogService.Write("开始同步"); |
| | | try |
| | | { |
| | | var model = sMainSub["model"].ToString(); |
| | | var entry = sMainSub["model"]["HENTRY"].ToString(); |
| | | var ppbomModel = sMainSub["ppbomModel"].ToString(); |
| | | var ppbomEntry = sMainSub["ppbomModel"]["HENTRY"].ToString(); |
| | | model = "[" + model.ToString() + "]"; |
| | | ppbomModel = "[" + ppbomModel.ToString() + "]"; |
| | | LogService.Write(model); |
| | | LogService.Write(entry); |
| | | LogService.Write(ppbomModel); |
| | | LogService.Write(ppbomEntry); |
| | | SQLHelper.ClsCN oCN = new SQLHelper.ClsCN(); |
| | | ListModels oListModels = new ListModels(); |
| | | |
| | | List<ClsWW_EntrustOrderBillMain_1> mainList = Newtonsoft.Json.JsonConvert.DeserializeObject<List<ClsWW_EntrustOrderBillMain_1>>(model); |
| | | List<ClsWW_EntrustOrderBillMainSub> subList = Newtonsoft.Json.JsonConvert.DeserializeObject<List<ClsWW_EntrustOrderBillMainSub>>(entry); |
| | | |
| | | |
| | | List<ClsWW_PPBomBill> ppbomMainList = Newtonsoft.Json.JsonConvert.DeserializeObject<List<ClsWW_PPBomBill>>(ppbomModel); |
| | | List<ClsWW_PPBomBillSubERP> ppbomSubList = Newtonsoft.Json.JsonConvert.DeserializeObject<List<ClsWW_PPBomBillSubERP>>(ppbomEntry); |
| | | // 添加空值检查 |
| | | if (mainList == null || mainList.Count == 0) |
| | | { |
| | | throw new Exception("主表数据反序列化失败"); |
| | | } |
| | | if (ppbomMainList == null || ppbomMainList.Count == 0) |
| | | { |
| | | throw new Exception("用料主表数据反序列化失败"); |
| | | } |
| | | |
| | | LogService.Write($"mainList 是否为空: {mainList == null}"); |
| | | LogService.Write($"mainList 数量: {mainList?.Count ?? 0}"); |
| | | LogService.Write($"ppbomMainList 是否为空: {ppbomMainList == null}"); |
| | | LogService.Write($"ppbomMainList 数量: {ppbomMainList?.Count ?? 0}"); |
| | | string sql = string.Empty; |
| | | LogService.Write(mainList); |
| | | LogService.Write(subList); |
| | | //保存 |
| | | oCN.BeginTran(); |
| | | sql = $"delete from WW_EntrustOrderBillMain where HInterID = {mainList[0].HInterID}"; |
| | | LogService.Write($"Hinter ID为{mainList[0].HInterID}"); |
| | | oCN.RunProc(sql); |
| | | sql = $"delete from WW_EntrustOrderBillSub where HInterID= {mainList[0].HInterID}"; |
| | | oCN.RunProc(sql); |
| | | |
| | | //委外用料清单 |
| | | sql = $"delete from WW_PPBomBillMain where HInterID = {mainList[0].HInterID}"; |
| | | LogService.Write($"Hinter ID为{mainList[0].HInterID}"); |
| | | oCN.RunProc(sql); |
| | | sql = $"delete from WW_PPBomBillSub where HInterID= {mainList[0].HInterID}"; |
| | | oCN.RunProc(sql); |
| | | |
| | | oCN.RunProc($@"insert into WW_EntrustOrderBillMain |
| | | (HInterID,HYear,HPeriod,HBillType,HBillSubType,HDate |
| | | ,HBillNo,HBillStatus |
| | | ,HAddress,HSSID,HSSDate,HSupID,HCurID |
| | | ,HExRate,HEmpID,HManagerID,HDeptID,HExplanation,HRemark,HInnerBillNo |
| | | ,HMaker,HMakeDate,HChecker,HCheckDate |
| | | ,HUpDater,HUpDateDate,HDeleteMan,HDeleteDate |
| | | ,HERPInterID,HERPBillType,HSUBORGID) |
| | | values({mainList[0].HInterID},'{mainList[0].HYear}','{mainList[0].HPeriod}','{mainList[0].HBillType}','{mainList[0].HBillSubType}','{mainList[0].HDate}','{mainList[0].HBillNo}' |
| | | ,'{mainList[0].HBillStatus}','{mainList[0].HAddress}','{mainList[0].HSSID}','{mainList[0].HSSDate}',{mainList[0].HSupID},'{mainList[0].HCurID}', |
| | | '{mainList[0].HExRate}','{mainList[0].HEmpID}','{mainList[0].HManagerID}','{mainList[0].HDeptID}','{mainList[0].HExplanation}','{mainList[0].HRemark}','{mainList[0].HInnerBillNo}','{mainList[0].HMaker}','{mainList[0].HMakeDate}' |
| | | ,'{mainList[0].HChecker}','{mainList[0].HCheckDate}','{mainList[0].HUpDater}','{mainList[0].HUpDateDate}','{mainList[0].HDeleteMan}','{mainList[0].HDeleteDate}','{mainList[0].HERPInterID}','{mainList[0].HERPBillType}','{mainList[0].HSUBORGID}' |
| | | |
| | | )", ref DBUtility.ClsPub.sExeReturnInfo); |
| | | LogService.Write("主表插入成功"); |
| | | foreach (var oSub in subList) |
| | | { |
| | | //新增子表: |
| | | oCN.RunProc($@" insert into WW_EntrustOrderBillSub |
| | | (HInterID,HEntryID,HMaterID,HUnitID,HQty,HPrice,HTaxPrice,HDiscountRate,HRelTaxPrice |
| | | ,HMoney,HTaxRate,HTaxMoney,HLineTotal,HlineTotalBB,HDate,HInStockQty,HInvoiceQty |
| | | ,HSeOrderBillNo,HSeOrderInterID,HSeOrderEntryID |
| | | ,HSourceInterID,HSourceEntryID,HSourceBillNo,HSourceBillType |
| | | ,HRelationQty,HBatChNo,HAuxPropID,HMTONo,HPlanMode,HRemark |
| | | ,HERPInterID,HERPEntryID,HBomID,HWhID,HSPID |
| | | ,HPOORderBillNo,HPOOrderSEQ |
| | | ) |
| | | values({oSub.HInterID},'{oSub.HEntryID}','{oSub.HMaterID}','{oSub.HUnitID}','{oSub.HQty}',{subList[0].HPrice},'{oSub.HTaxPrice}', |
| | | {oSub.HDiscountRate},'{oSub.HRelTaxPrice}','{oSub.HMoney}','{oSub.HTaxRate}','{oSub.HTaxMoney}',{subList[0].HLineTotal },'{oSub.HlineTotalBB}','{oSub.HDate}','{oSub.HInStockQty}','{oSub.HInvoiceQty}' |
| | | ,'{oSub.HSeOrderBillNo}','{oSub.HSeOrderInterID}','{oSub.HSeOrderEntryID}','{oSub.HSourceInterID}','{oSub.HSourceEntryID}','{oSub.HSourceBillNo}','{oSub.HSourceBillType}','{oSub.HRelationQty}','{oSub.HBatChNo}','{oSub.HAuxPropID}','{oSub.HMTONo}','{oSub.HPlanMode}','{oSub.HRemark}', |
| | | {oSub.HERPInterID},'{oSub.HERPEntryID}','{oSub.HBomID}','{oSub.HWhID}',{subList[0].HSPID },'{oSub.HPOORderBillNo}','{oSub.HPOOrderSEQ}' |
| | | )", ref DBUtility.ClsPub.sExeReturnInfo); |
| | | } |
| | | LogService.Write("子表插入成功"); |
| | | |
| | | //委外用料清单插入 |
| | | oCN.RunProc($@"insert into WW_PPBomBillMain |
| | | (HInterID,HYear,HPeriod,HBillType,HBillSubType,HDate |
| | | ,HBillNo,HBillStatus,HICMOInterID,HICMOEntryID,HSUBBILLNO,HSUBREQENTRYSEQ |
| | | ,HMaterID,HUnitID,HQty,HSupID,HDEPTID,HPOOrderBillNo,HPOOrderSeq |
| | | ,HMaker,HMakeDate,HChecker,HCheckDate,HUpDater,HUpDateDate |
| | | ,HSeOrderBillNo,HSeOrderInterID,HSeOrderEntryID,HSeOrderSEQ |
| | | ,HPRDORGID,HENTRUSTORGID,HPARENTOWNERID,HPARENTOWNERTYPEID |
| | | ,HERPInterID,HERPBillType,HSETTLEORGID,HREQSRC) |
| | | values({ppbomMainList[0].HInterID},'{ppbomMainList[0].HYear}','{ppbomMainList[0].HPeriod}','{ppbomMainList[0].HBillType}','{ppbomMainList[0].HBillSubType}','{ppbomMainList[0].HDate}','{ppbomMainList[0].HBillNo}' |
| | | ,'{ppbomMainList[0].HBillStatus}','{ppbomMainList[0].HICMOInterID}','{ppbomMainList[0].HICMOEntryID}','{ppbomMainList[0].HSUBBILLNO}','{ppbomMainList[0].HSUBREQENTRYSEQ}','{ppbomMainList[0].HMaterID}',{ppbomMainList[0].HUnitID},'{ppbomMainList[0].HQty}','{ppbomMainList[0].HSupID}','{ppbomMainList[0].HDeptID}', |
| | | '{ppbomMainList[0].HPOOrderBillNo}','{ppbomMainList[0].HPOOrderSeq}','{ppbomMainList[0].HMaker}','{ppbomMainList[0].HMakeDate}','{ppbomMainList[0].HChecker}','{ppbomMainList[0].HCheckDate}','{ppbomMainList[0].HUpDater}','{ppbomMainList[0].HUpDateDate}','{ppbomMainList[0].HSeOrderBillNo}','{ppbomMainList[0].HSeOrderInterID}','{ppbomMainList[0].HSeOrderEntryID}','{ppbomMainList[0].HSeOrderSEQ}' |
| | | ,'{ppbomMainList[0].HPRDORGID}','{ppbomMainList[0].HENTRUSTORGID}','{ppbomMainList[0].HPARENTOWNERID}' |
| | | ,'{ppbomMainList[0].HPARENTOWNERTYPEID}','{ppbomMainList[0].HERPInterID}','{ppbomMainList[0].HERPBillType}','{ppbomMainList[0].HSETTLEORGID}','{ppbomMainList[0].HREQSRC}' |
| | | |
| | | )", ref DBUtility.ClsPub.sExeReturnInfo); |
| | | LogService.Write("委外清单主表插入成功"); |
| | | |
| | | foreach (var oSub in ppbomSubList) |
| | | { |
| | | |
| | | //新增子表: |
| | | oCN.RunProc($@" insert into WW_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 |
| | | ,HPROCESSID,HBASEUNITID,HPROJECTNO,HOPERID,HSEQ |
| | | ,HSTOCKSTATUSID,HRESERVETYPE |
| | | ) |
| | | values({oSub.HInterID},'{oSub.HEntryID}','{oSub.HMaterID}','{oSub.HUnitID}','{oSub.HQty}',{oSub.HQtyMust},'{oSub.HWHID}', |
| | | '{oSub.HRemark}','{oSub.HSourceInterID}','{oSub.HSourceEntryID}','{oSub.HSourceBillNo}','{oSub.HSourceBillType}',{oSub.HICMOInterID },'{oSub.HICMOEntryID}','{oSub.HICMOBillNo}','{oSub.HCHILDSUPPLYORGID}','{oSub.HSUPPLYORGID}' |
| | | ,'{oSub.HENTRUSTPICKORGID}','{oSub.HSRCTRANSORGID}','{oSub.HGROUPBYOWNERID}','{oSub.HOWNERID}','{oSub.HOWNERTYPEID}','{oSub.HRelationQty}','{oSub.HMoveStockQty}','{oSub.HAuxPropID}','{oSub.HBatChNo}','{oSub.HMTONo}','{oSub.HQtyScrap}', |
| | | {oSub.HERPInterID},'{oSub.HERPEntryID}','{oSub.HBackRelationQty}','{oSub.HPROCESSID}',{oSub.HBASEUNITID },'{oSub.HPROJECTNO}','{oSub.HOPERID}','{oSub.HSEQ}','{oSub.HSTOCKSTATUSID}','{oSub.HRESERVETYPE}' |
| | | )", ref DBUtility.ClsPub.sExeReturnInfo); |
| | | } |
| | | LogService.Write("子表插入成功"); |
| | | |
| | | |
| | | |
| | | |
| | | oCN.Commit(); |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | objJsonResult.code = "1"; |
| | | objJsonResult.count = 1; |
| | | objJsonResult.Message = "保存成功!"; |
| | | objJsonResult.data = 1; |
| | | return objJsonResult; |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | LogService.Write("异常信息:" + e.ToString()); |
| | | objJsonResult.code = "0"; |
| | | objJsonResult.count = 0; |
| | | objJsonResult.Message = "保存失败!" + e.ToString(); |
| | | objJsonResult.data = 1; |
| | | return objJsonResult; |
| | | } |
| | | } |
| | | #endregion |
| | | } |
| | | } |