1
duhe
2023-07-10 ea52bb39a168bb3168f31bb81ef9e3e6671cfba8
WebAPI/Controllers/SCGL/Èռƻ®¹ÜÀí/JIT_DayPlanPlatFormBillController.cs
@@ -213,8 +213,7 @@
                        HBillNo = DBUtility.ClsPub.CreateBillCode_Prod(BillType, ref DBUtility.ClsPub.sExeReturnInfo, true);//获得一个新的单据号
                        HInterID = DBUtility.ClsPub.CreateBillID_Prod(BillType, ref DBUtility.ClsPub.sExeReturnInfo);//获得一个新的id
                        //主表
                        oCN.RunProc("insert into Sc_WorkBillSortBillMain(HInterID,HBillNo,HYear,HPeriod,HBillType," +
                        string sql = $"insert into Sc_WorkBillSortBillMain(HInterID,HBillNo,HYear,HPeriod,HBillType," +
                            "HBillSubType,HDate,HBillStatus,HMaker,HMakeDate,HICMOBillNo,HOrderType," +
                            "HICMOEntrySEQ,HWorkShopID,HSourceID, HYX, HProdORGID," +
                            " HMaterID, HMaterName, HMaterModel, HUnitID, HSeOrderBillQty," +
@@ -227,7 +226,11 @@
                            $" {(HMaterID == "" ? 0.ToString() : HMaterID)}, '{HMaterName}', '{HMaterModel}', {(HUnitID == "" ? 0.ToString() : HUnitID)}, {(HSeOrderBillQty == "" ? 0.ToString() : HSeOrderBillQty)}," +
                            $" 0, {(HSplitQty == "" ? 0.ToString() : HSplitQty)}, {(HDayPlanSumQty == "" ? 0.ToString() : HDayPlanSumQty)},'{HPlanBeginDate}'," +
                            $"'{HSeOrderBillNo}','{HICMOBillType}',{(HSourceStockInQty == "" ? 0.ToString() : HSourceStockInQty)},{(HLeftPlanQty == "" ? 0.ToString() : HLeftPlanQty)},'{HOrderLev}',getdate()," +
                            $"{HMainSourceInterID},{HMainSourceEntryID},{HMainSourceInterID},{HMainSourceEntryID},{HPlanQty})");
                            $"{HMainSourceInterID},{HMainSourceEntryID},{HMainSourceInterID},{HMainSourceEntryID},{HPlanQty})";
                        //LogService.Write("sql:" + sql);
                        //主表
                        oCN.RunProc(sql);
                    }
                    else
                    {
@@ -762,14 +765,14 @@
(
select distinct a.HProdORGID FStockOrgId,T2.FMATERIALID,FNumber from Sc_WorkBillSortBillMain a
join Sc_WorkBillSortBillSub b on a.HInterID = b.HInterID
join AIS20210811135644..T_PRD_PPBOM T1 on a.HICMOInterID_Sec = t1.FMoId and a.HICMOEntryID_Sec = t1.FMOENTRYID
LEFT JOIN  AIS20210811135644..T_PRD_PPBOMENTRY T2 on T1.FID = t2.FID
join  AIS20210811135644..T_BD_MATERIAL T3 on T2.FMATERIALID = T3.FMATERIALID
join AIS20230129011339..T_PRD_PPBOM T1 on a.HICMOInterID_Sec = t1.FMoId and a.HICMOEntryID_Sec = t1.FMOENTRYID
LEFT JOIN  AIS20230129011339..T_PRD_PPBOMENTRY T2 on T1.FID = t2.FID
join  AIS20230129011339..T_BD_MATERIAL T3 on T2.FMATERIALID = T3.FMATERIALID
) T1 
JOIN  AIS20210811135644..T_BD_MATERIAL b on  t1.FNUMBER = b.FNUMBER
LEFT JOIN  AIS20210811135644..T_STK_Inventory a on b.FMATERIALID = a.FMATERIALID
LEFT join (select distinct fitemid,fformid,FNUMBER from  AIS20210811135644..V_ITEMCLASS_OWNER) c on a.FOwnerTypeId = c.fformid and a.FOWNERID = c.fitemid
join  AIS20210811135644..t_BD_Stock d on a.FSTOCKID =d.FSTOCKID
JOIN  AIS20230129011339..T_BD_MATERIAL b on  t1.FNUMBER = b.FNUMBER
LEFT JOIN  AIS20230129011339..T_STK_Inventory a on b.FMATERIALID = a.FMATERIALID
LEFT join (select distinct fitemid,fformid,FNUMBER from  AIS20230129011339..V_ITEMCLASS_OWNER) c on a.FOwnerTypeId = c.fformid and a.FOWNERID = c.fitemid
join  AIS20230129011339..t_BD_Stock d on a.FSTOCKID =d.FSTOCKID
where a.FBASEQTY>0 
", "SC_WORKBILLSORTBILLMAIN");
                ListInventory = ds.ToModelList<PRD_Inventory>();
@@ -795,10 +798,10 @@
where a.HInterID IN ({0})
group by HICMOEntryID_Sec 
) a
join  AIS20210811135644..T_PRD_PPBOM T1  on a.FPRDMOENTYID = t1.FMOENTRYID
LEFT JOIN AIS20210811135644..T_PRD_PPBOMENTRY t2 on T1.FID = T2.FID
LEFT JOIN AIS20210811135644..T_PRD_PPBOMENTRY_Q t3 on t2.FENTRYID = T3.FENTRYID
LEFT JOIN AIS20210811135644..T_BD_MATERIAL T4 ON T2.FMATERIALID = T4.FMATERIALID
join  AIS20230129011339..T_PRD_PPBOM T1  on a.FPRDMOENTYID = t1.FMOENTRYID
LEFT JOIN AIS20230129011339..T_PRD_PPBOMENTRY t2 on T1.FID = T2.FID
LEFT JOIN AIS20230129011339..T_PRD_PPBOMENTRY_Q t3 on t2.FENTRYID = T3.FENTRYID
LEFT JOIN AIS20230129011339..T_BD_MATERIAL T4 ON T2.FMATERIALID = T4.FMATERIALID
) t1
group by FPRDMOENTYID,FMATERIALID
", fDayPlanFids);
@@ -1156,6 +1159,827 @@
        }
        #endregion
        #region ç”Ÿäº§æ—¥è®¡åˆ’平台 ææ–™è¿ç®—
        #region æ—¥è®¡åˆ’展开数据明细
        public class DayPlanPpbom
        {
            /// <summary>
            /// æ—¥è®¡åˆ’工单主ID
            /// </summary>
            public long FID { get; set; }
            /// <summary>
            /// ç”Ÿäº§è®¢å•号
            /// </summary>
            public string FBILLNO { get; set; }
            /// <summary>
            /// æ—¥è®¡åˆ’明细日期
            /// </summary>
            public DateTime FHMASTERDATE { get; set; }
            /// <summary>
            /// æ—¥è®¡åˆ’明细数量
            /// </summary>
            public decimal FHQTY { get; set; }
            /// <summary>
            /// é½å¥—æ•°
            /// </summary>
            public decimal FCOMPLETECOUNT { get; set; }
            /// <summary>
            /// ç”Ÿäº§è®¢å•工单ID
            /// </summary>
            public long FPRDMOMAINID { get; set; }
            /// <summary>
            /// å­è¡¨ID
            /// </summary>
            public int FENTRYID { get; set; }
            /// <summary>
            /// å•位用料
            /// </summary>
            public decimal FNeedQty { get; set; }
            /// <summary>
            /// ç‰©æ–™ID
            /// </summary>
            public string FMATERIALID { get; set; }
            /// <summary>
            /// æå‰å¤©æ•°
            /// </summary>
            public int FFIXLEADTIME { get; set; }
            /// <summary>
            ///最大包装
            /// </summary>
            public decimal FMAXPOQTY { get; set; }
            /// <summary>
            /// æœ€å°åŒ…装量
            /// </summary>
            public decimal FMINPOQTY { get; set; }
            /// <summary>
            /// ç‰©æ–™ç¼–码
            /// </summary>
            public string FNumber { get; set; }
            /// <summary>
            /// å®žé™…需求
            /// </summary>
            public decimal NeedQty { get; set; }
            /// <summary>
            /// åº“存组织
            /// </summary>
            public long FStockOrgId { get; set; }
            /// <summary>
            /// jit物料分类
            /// </summary>
            public string FJITmaterialGroup { get; set; }
            /// <summary>
            /// JIT物料需求供货周期
            /// </summary>
            public string FJITMaterielDemand { get; set; }
            /// <summary>
            /// JIT安全库存
            /// </summary>
            public string FJITSafeStock { get; set; }
            /// <summary>
            /// ç‰©æ–™å±žæ€§
            /// </summary>
            public string FErpClsID { get; set; }
            /// <summary>
            /// éœ€æ±‚单号(销售订单号)
            /// </summary>
            public string FXQD { get; set; }
            /// <summary>
            /// æ—¥è®¡åˆ’工单单号
            /// </summary>
            public string FDAYPLANBILLNO { get; set; }
            /// <summary>
            /// ç”Ÿäº§è½¦é—´ç¼–码
            /// </summary>
            public string FWORKSHOPNUMBER { get; set; }
        }
        #endregion
        #region é‡‡è´­è®¢å•物料库存
        public class PurchaseInventory
        {
            /// <summary>
            /// é‡‡è´­FID
            /// </summary>
            public long FID { get; set; }
            //采购订单单号
            public string FBillNo { get; set; }
            /// <summary>
            /// é‡‡è´­å­è¡¨æ ‡è¯†
            /// </summary>
            public long FENTRYID { get; set; }
            /// <summary>
            /// ä¾›åº”商id
            /// </summary>
            public long FSUPPLIERID { get; set; }
            /// <summary>
            /// ä¾›åº”商名称
            /// </summary>
            public string FNUMBER { get; set; }
            /// <summary>
            /// ç‰©æ–™ID
            /// </summary>
            public string FMATERIALID { get; set; }
            /// <summary>
            /// ç‰©æ–™ç¼–码
            /// </summary>
            public string FMATERIALNUMBER { get; set; }
            /// <summary>
            /// é‡‡è´­æ•°é‡
            /// </summary>
            public decimal FQTY { get; set; }
            /// <summary>
            /// é‡‡è´­ç»„织
            /// </summary>
            public long FStockOrgId { get; set; }
            /// <summary>
            /// ç»„织编码
            /// </summary>
            public string FORGNumber { get; set; }
            /// <summary>
            /// æå‰æœŸ
            /// </summary>
            public int FFIXLEADTIME { get; set; }
            /// <summary>
            /// éœ€æ±‚单号
            /// </summary>
            public string FXQD { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•上的创建人
            /// </summary>
            public string FCREATORID { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•上的创建人名称
            /// </summary>
            public string FName { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•上的采购日期
            /// </summary>
            public DateTime FDate { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•上的交货日期
            /// </summary>
            public DateTime FDeliveryDate { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•表头摘要
            /// </summary>
            public string F_QIMB_NOTE { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•表体备注
            /// </summary>
            public string FNOTE { get; set; }
            //采购部门
            public string FPURCHASEDEPTNUMBER { get; set; }
            /// <summary>
            /// æ”¶æ–™ä½†æ˜¯æ²¡å…¥åº“部分 éœ€è¦ä¼˜å…ˆåŽ»æ‰£é™¤
            /// </summary>
            public decimal FReceiveNotInQty { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•数量
            /// </summary>
            public decimal FPURCHASEQTY { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•关联数量
            /// </summary>
            public decimal FJOINQTY { get; set; }
            /// <summary>
            /// æ”¶æ–™å•数量
            /// </summary>
            public decimal FReceiveQty { get; set; }
        }
        #endregion
        #region ææ–™è®¡åˆ’临时储存
        public class PODemandPlanTemp
        {
            /// <summary>
            /// æ—¥è®¡åˆ’工单主ID
            /// </summary>
            public long FID { get; set; }
            /// <summary>
            /// æ—¥è®¡åˆ’工单编号
            /// </summary>
            public string FBILLNO { get; set; }
            /// <summary>
            /// æ—¥è®¡åˆ’明细日期
            /// </summary>
            public DateTime FHMASTERDATE { get; set; }
            /// <summary>
            /// æ—¥è®¡åˆ’明细数量
            /// </summary>
            public decimal FHQTY { get; set; }
            /// <summary>
            /// ç”Ÿäº§è®¢å•工单ID
            /// </summary>
            public long FPRDMOMAINID { get; set; }
            /// <summary>
            /// å­è¡¨ID
            /// </summary>
            public int FENTRYID { get; set; }
            /// <summary>
            /// æ•°é‡
            /// </summary>
            public decimal FQty { get; set; }
            /// <summary>
            /// ç‰©æ–™ID
            /// </summary>
            public string FMATERIALID { get; set; }
            /// <summary>
            /// ç‰©æ–™ç¼–码
            /// </summary>
            public string FNumber { get; set; }
            /// <summary>
            /// é‡‡è´­FID
            /// </summary>
            public long PurchseFID { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•单号
            /// </summary>
            public string PurchseFBillNo { get; set; }
            /// <summary>
            /// é‡‡è´­å­è¡¨æ ‡è¯†
            /// </summary>
            public long PurchseFentryID { get; set; }
            /// <summary>
            /// ä¾›åº”商id
            /// </summary>
            public long FSUPPLIERID { get; set; }
            /// <summary>
            /// ä¾›åº”商名称
            /// </summary>
            public string PurchseFNUMBER { get; set; }
            /// <summary>
            /// æ—¥è®¡åˆ’日期
            /// </summary>
            public DateTime OLDDATE { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•数量
            /// </summary>
            public decimal PurchseFqty { get; set; }
            /// <summary>
            /// æå‰æœŸ
            /// </summary>
            public double FFIXLEADTIME { get; set; }
            /// <summary>
            /// é‡‡è´­ç»„织
            /// </summary>
            public long FStockOrgId { get; set; }
            /// <summary>
            /// ç»„织编码
            /// </summary>
            public string FORGNumber { get; set; }
            /// <summary>
            /// ç‰©æ–™å±žæ€§
            /// </summary>
            public string FErpClsID { get; set; }
            /// <summary>
            /// éœ€æ±‚单号
            /// </summary>
            public string FXQD { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•上的创建人
            /// </summary>
            public string FCREATORID { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•上的创建人名称
            /// </summary>
            public string FName { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•上的采购日期
            /// </summary>
            public DateTime FDate { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•上的交货日期
            /// </summary>
            public DateTime FDeliveryDate { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•表头摘要
            /// </summary>
            public string F_QIMB_NOTE { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•表体备注
            /// </summary>
            public string FNOTE { get; set; }
            /// <summary>
            /// é‡‡è´­éƒ¨é—¨
            /// </summary>
            public string FPURCHASEDEPTNUMBER { get; set; }
            /// <summary>
            /// æ—¥è®¡åˆ’工单单号
            /// </summary>
            public string FDAYPLANBILLNO { get; set; }
            /// <summary>
            /// ç”Ÿäº§è½¦é—´ç¼–码
            /// </summary>
            public string FWORKSHOPNUMBER { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•数量
            /// </summary>
            public decimal FPURCHASEQTY { get; set; }
            /// <summary>
            /// é‡‡è´­è®¢å•关联数量
            /// </summary>
            public decimal FJOINQTY { get; set; }
        }
        #endregion
        [Route("JIT_DayPlanPlatFormBill/JIT_TLYS")]
        [HttpGet]
        public object JIT_TLYS(string sWhere, string user)
        {
            try
            {
                omdelMian = JsonConvert.DeserializeObject<Sc_WorkBillSortBillMain>(sWhere);
                DataSet DaSet = oCN.RunProcReturn($"select * from JIT_MOMaterReadysBill where HWorkShopID={omdelMian.HWorkShopID} and HProdORGID={omdelMian.HProdORGID}", "JIT_MOMaterReadysBill");
                if (DaSet.Tables[0].Rows.Count == 0)
                {
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = "没有数据,请先齐套分析!";
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                string fProWorkShopId = omdelMian.HWorkShopID.ToString();
                var fPrdOrgId = omdelMian.HProdORGID;
                LogService.Write($"提料计划重算 è½¦é—´ï¼š{fProWorkShopId},组织:{fPrdOrgId}");
                Stopwatch sw = new Stopwatch();
                sw.Start();//开始计时
                           //提料计划预处理 æ¸…理提料计划单数据 æ›´æ–°é‡‡è´­è®¢å•提料计划数量 å¹¶ä¸”查询出需要进行运算的数据
                oCN.BeginTran();  //开始事务
                ds = oCN.RunProcReturn($"exec h_p_PROC_JIT_TLPLANYCL '{fProWorkShopId}','{fPrdOrgId}'", "h_p_PROC_JIT_TLPLANYCL");
                List<DayPlanPpbom> DayPlanPpbom = ds.ToModelList<DayPlanPpbom>();
                if (DayPlanPpbom.Count == 0)
                {
                    oCN.RollBack();//回滚事务
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = "无数据运算!";
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                //采购订单数据 ï¼ˆå‰©ä½™æ”¶æ–™æ•°é‡ï¼‰
                //t2.FXQD  t2.FSTOCKINQTY,t2.FReceiveQty æœ¬åœ°æ²¡æœ‰è¿™äº›å­—段
                string sql = string.Format(@"
 /*dialect*/
select t4.FSTOCKINQTY,t4.FReceiveQty,t1.FID,t1.FBillNo,t2.FENTRYID,t1.FSUPPLIERID,t3.fnumber,t2.FMATERIALID,(t4.FREMAINRECEIVEQTY-t2.FPODemandPlanCount)FQTY
,FPurchaseOrgId FStockOrgId,t5.FNUMBER FORGNumber,FCloseStatus,FMRPCLOSESTATUS,FPURCHASEDEPTID,t7.FNUMBER as FPURCHASEDEPTNUMBER
,t1.FCREATORID,t8.FName ,t1.FDate,tD.FDeliveryDate,t2.FNOTE,(t4.FReceiveQty - t4.FSTOCKINQTY) as  FReceiveNotInQty,'' FXQD,T2.FQTY AS FPURCHASEQTY,FJOINQTY,
isnull((select top 1 HLeadTime +  HLeadTime_Sec from Cg_PODemandPlanConfigBillMain a
join Cg_PODemandPlanConfigBillSub b on a.HInterID =b.HInterID
left join Xt_ORGANIZATIONS o on a.HOrgID=o.HItemID
left join Gy_Supplier s on b.HSupplierID=s.HItemID
 where o.HNumber = t5.FNUMBER and s.HNumber = t3.FNUMBER), 0)FFIXLEADTIME
from AIS20230129011339..t_PUR_POOrder t1
join AIS20230129011339..t_PUR_POOrderEntry t2 on t1.FID = t2.FID
join AIS20230129011339..t_BD_Supplier t3 on t1.FSUPPLIERID = t3.FSUPPLIERID
join  AIS20230129011339..T_PUR_POORDERENTRY_R t4 on t2.FENTRYID = t4.FENTRYID
join  AIS20230129011339..T_PUR_POORDERENTRY_D tD on t2.FENTRYID = tD.FENTRYID
join AIS20230129011339..T_ORG_Organizations t5 on t1.FPurchaseOrgId = t5.FORGID
join AIS20230129011339..T_SEC_user t8 on t1.FCREATORID = t8.FuserId
join AIS20230129011339..T_BD_DEPARTMENT T7 ON t1.FPURCHASEDEPTID = T7.FDEPTID
where t4.FREMAINRECEIVEQTY-t2.FPODemandPlanCount>0
and FCloseStatus in('A') and FMRPCLOSESTATUS in('A')
and t1.FBillTypeID in('83d822ca3e374b4ab01e5dd46a0062bd','6d01d059713d42a28bb976c90a121142')
and FPurchaseOrgId = '{0}'
", fPrdOrgId);
                ds = oCN.RunProcReturn(sql, "PurchaseInventoryList");
                if (ds.Tables[0].Rows.Count == 0) {
                    oCN.RollBack();//回滚事务
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = "查无采购订单数据!";
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                List<PurchaseInventory> PurchaseInventory = ds.ToModelList<PurchaseInventory>();
                //物料+库存组织分类
                var MaterialIDList = DayPlanPpbom.GroupBy(p => new { p.FMATERIALID, p.FStockOrgId }).Select(x => new PODemandPlanTemp { FMATERIALID = x.Key.FMATERIALID, FStockOrgId = x.Key.FStockOrgId }).ToList();
                //提料计划数据集临时存储集合
                List<PODemandPlanTemp> PODemandPlanTemp = new List<PODemandPlanTemp>();
                //sql集合 æ›´æ–°é‡‡è´­è®¢å•占用的提料计划数量
                List<string> sqlList = new List<string>();
                foreach (var item in MaterialIDList)
                {
                    //this.View.Session["ProcessRateValue"] = Convert.ToInt32((Convert.ToDecimal(75) / MaterialIDList.Count) * i);
                    //当前物料和库存组织对应的需进行提料计划的数据
                    List<DayPlanPpbom> _DayPlanPpbom = DayPlanPpbom.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId).ToList();
                    decimal NeedQty = 0;
                    foreach (var _item in _DayPlanPpbom)
                    {
                        //查询有没有可以用于提料的采购订单数据
                        var _PurchaseInventory = PurchaseInventory.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId && x.FQTY > 0).OrderBy(x => x.FENTRYID).ToList();
                        if (_PurchaseInventory.Count == 0)
                        {
                            //无采购订单直接下一个物料
                            sql = $"INSERT INTO JIT_TLPLANERROR(HROGID,HUSERID,HWORKSHOPID,HDAYPLANID,HDAYPLANENTRYID,HMATERIALID,HQTY,HTYPE) VALUES({fPrdOrgId},{user},{fProWorkShopId},{_item.FID},{_item.FENTRYID},{_item.FMATERIALID},{_item.NeedQty},0) ";
                            sqlList.Add(sql);
                            break;
                        }
                        //需求数量
                        NeedQty = _item.NeedQty;
                        //增加一个销售订单号匹配的逻辑 ä¼˜å…ˆå¾ªçޝ
                        var PurchaseInventoryBySalOrder = _PurchaseInventory.Where(x => x.FXQD == _item.FXQD).OrderBy(x => x.FENTRYID).ToList();
                        if (PurchaseInventoryBySalOrder.Count > 0)
                        {
                            foreach (var Purchase in PurchaseInventoryBySalOrder)
                            {
                                double _FFIXLEADTIME = Purchase.FFIXLEADTIME;//提前期
                                DateTime _DATE = Convert.ToDateTime(_item.FHMASTERDATE).AddDays(-_FFIXLEADTIME);
                                if (Purchase.FQTY >= NeedQty)
                                {
                                    PODemandPlanTemp.Add(new PODemandPlanTemp
                                    {
                                        FID = _item.FID,
                                        FHMASTERDATE = _DATE,
                                        FQty = NeedQty,
                                        FBILLNO = _item.FBILLNO,
                                        FENTRYID = _item.FENTRYID,
                                        FMATERIALID = _item.FMATERIALID,
                                        FNumber = _item.FNumber,
                                        OLDDATE = _item.FHMASTERDATE,
                                        FFIXLEADTIME = _FFIXLEADTIME,
                                        FErpClsID = _item.FErpClsID,
                                        FWORKSHOPNUMBER = _item.FWORKSHOPNUMBER,
                                        FDAYPLANBILLNO = _item.FDAYPLANBILLNO,
                                        PurchseFentryID = Purchase.FENTRYID,
                                        FSUPPLIERID = Purchase.FSUPPLIERID,
                                        PurchseFNUMBER = Purchase.FNUMBER,
                                        PurchseFBillNo = Purchase.FBillNo,
                                        PurchseFqty = Purchase.FQTY,
                                        FStockOrgId = Purchase.FStockOrgId, //采购组织
                                        FORGNumber = Purchase.FORGNumber,
                                        FPURCHASEDEPTNUMBER = Purchase.FPURCHASEDEPTNUMBER,
                                        FXQD = _item.FXQD,
                                        FCREATORID = Purchase.FCREATORID,
                                        FName = Purchase.FName,
                                        FDate = Purchase.FDate,
                                        FDeliveryDate = Purchase.FDeliveryDate,
                                        F_QIMB_NOTE = Purchase.F_QIMB_NOTE,
                                        FNOTE = Purchase.FNOTE,
                                        FPURCHASEQTY = Purchase.FPURCHASEQTY,
                                        FJOINQTY = Purchase.FJOINQTY
                                    });
                                    //扣除日计划明细已被分配的数量
                                    _item.NeedQty = 0;
                                    //扣除当前行对应采购订单数量
                                    Purchase.FQTY -= NeedQty;
                                    //更新采购订单
                                    //sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount  =isnull(FPODemandPlanCount,0)+  '{NeedQty}' where FENTRYID = {Purchase.FENTRYID}");
                                    //需求数量变为0
                                    NeedQty = 0;
                                    break;
                                }
                                else//采购订单数据不能满足订单所需数量
                                {
                                    //采购订单数量
                                    decimal _NeedQty = Purchase.FQTY;
                                    PODemandPlanTemp.Add(new PODemandPlanTemp
                                    {
                                        FID = _item.FID,
                                        FHMASTERDATE = _DATE,
                                        FQty = _NeedQty,
                                        FBILLNO = _item.FBILLNO,
                                        FENTRYID = _item.FENTRYID,
                                        FMATERIALID = _item.FMATERIALID,
                                        FNumber = _item.FNumber,
                                        OLDDATE = _item.FHMASTERDATE,
                                        FFIXLEADTIME = _FFIXLEADTIME,
                                        FErpClsID = _item.FErpClsID,
                                        FWORKSHOPNUMBER = _item.FWORKSHOPNUMBER,
                                        FDAYPLANBILLNO = _item.FDAYPLANBILLNO,
                                        PurchseFentryID = Purchase.FENTRYID,
                                        FSUPPLIERID = Purchase.FSUPPLIERID,
                                        PurchseFNUMBER = Purchase.FNUMBER,
                                        PurchseFBillNo = Purchase.FBillNo,
                                        PurchseFqty = Purchase.FQTY,
                                        FStockOrgId = Purchase.FStockOrgId, //采购组织
                                        FORGNumber = Purchase.FORGNumber,
                                        FPURCHASEDEPTNUMBER = Purchase.FPURCHASEDEPTNUMBER,
                                        FXQD = _item.FXQD,
                                        FCREATORID = Purchase.FCREATORID,
                                        FName = Purchase.FName,
                                        FDate = Purchase.FDate,
                                        FDeliveryDate = Purchase.FDeliveryDate,
                                        F_QIMB_NOTE = Purchase.F_QIMB_NOTE,
                                        FNOTE = Purchase.FNOTE,
                                        FPURCHASEQTY = Purchase.FPURCHASEQTY,
                                        FJOINQTY = Purchase.FJOINQTY
                                    });
                                    //更新采购订单
                                    //sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount = isnull(FPODemandPlanCount,0)+ '{Purchase.FQTY}' where FENTRYID = {Purchase.FENTRYID}");
                                    //更新订单需求数量
                                    NeedQty = NeedQty - Purchase.FQTY;
                                    //扣除日计划明细已被分配的数量
                                    _item.NeedQty -= _NeedQty;
                                    //扣除当前行对应采购订单数量
                                    Purchase.FQTY = 0;
                                }
                            }
                        }
                        if (NeedQty == 0)
                            continue;
                        var PurchaseInventoryElse = _PurchaseInventory.Where(x => x.FXQD != _item.FXQD).OrderBy(x => x.FENTRYID).ToList();
                        foreach (var Purchase in PurchaseInventoryElse)
                        {
                            double _FFIXLEADTIME = Purchase.FFIXLEADTIME;//提前期
                            DateTime _DATE = Convert.ToDateTime(_item.FHMASTERDATE).AddDays(-_FFIXLEADTIME);
                            if (Purchase.FQTY >= NeedQty)
                            {
                                PODemandPlanTemp.Add(new PODemandPlanTemp
                                {
                                    FID = _item.FID,
                                    FHMASTERDATE = _DATE,
                                    FQty = _item.NeedQty,
                                    FBILLNO = _item.FBILLNO,
                                    FENTRYID = _item.FENTRYID,
                                    FMATERIALID = _item.FMATERIALID,
                                    FNumber = _item.FNumber,
                                    OLDDATE = _item.FHMASTERDATE,
                                    FFIXLEADTIME = _FFIXLEADTIME,
                                    FErpClsID = _item.FErpClsID,
                                    FWORKSHOPNUMBER = _item.FWORKSHOPNUMBER,
                                    FDAYPLANBILLNO = _item.FDAYPLANBILLNO,
                                    PurchseFentryID = Purchase.FENTRYID,
                                    FSUPPLIERID = Purchase.FSUPPLIERID,
                                    PurchseFNUMBER = Purchase.FNUMBER,
                                    PurchseFBillNo = Purchase.FBillNo,
                                    PurchseFqty = Purchase.FQTY,
                                    FStockOrgId = Purchase.FStockOrgId, //采购组织
                                    FORGNumber = Purchase.FORGNumber,
                                    FPURCHASEDEPTNUMBER = Purchase.FPURCHASEDEPTNUMBER,
                                    FXQD = _item.FXQD,
                                    FCREATORID = Purchase.FCREATORID,
                                    FName = Purchase.FName,
                                    FDate = Purchase.FDate,
                                    FDeliveryDate = Purchase.FDeliveryDate,
                                    F_QIMB_NOTE = Purchase.F_QIMB_NOTE,
                                    FNOTE = Purchase.FNOTE,
                                    FPURCHASEQTY = Purchase.FPURCHASEQTY,
                                    FJOINQTY = Purchase.FJOINQTY
                                });
                                //更新采购订单
                                //sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount  =isnull(FPODemandPlanCount,0)+  '{NeedQty}' where FENTRYID = {Purchase.FENTRYID}");
                                //扣除日计划明细已被分配的数量
                                _item.NeedQty = 0;
                                //扣除当前行对应采购订单数量
                                Purchase.FQTY -= NeedQty;
                                //需求数量变为0
                                NeedQty = 0;
                                break;
                            }
                            else//采购订单数据不能满足订单所需数量
                            {
                                //更新总需求数量
                                NeedQty = NeedQty - Purchase.FQTY;
                                //采购订单数量
                                decimal _NeedQty = Purchase.FQTY;
                                PODemandPlanTemp.Add(new PODemandPlanTemp
                                {
                                    FID = _item.FID,
                                    FHMASTERDATE = _DATE,
                                    FQty = _NeedQty,
                                    FBILLNO = _item.FBILLNO,
                                    FENTRYID = _item.FENTRYID,
                                    FMATERIALID = _item.FMATERIALID,
                                    FNumber = _item.FNumber,
                                    OLDDATE = _item.FHMASTERDATE,
                                    FFIXLEADTIME = _FFIXLEADTIME,
                                    FErpClsID = _item.FErpClsID,
                                    FWORKSHOPNUMBER = _item.FWORKSHOPNUMBER,
                                    FDAYPLANBILLNO = _item.FDAYPLANBILLNO,
                                    PurchseFentryID = Purchase.FENTRYID,
                                    FSUPPLIERID = Purchase.FSUPPLIERID,
                                    PurchseFNUMBER = Purchase.FNUMBER,
                                    PurchseFBillNo = Purchase.FBillNo,
                                    PurchseFqty = Purchase.FQTY,
                                    FStockOrgId = Purchase.FStockOrgId, //采购组织
                                    FORGNumber = Purchase.FORGNumber,
                                    FPURCHASEDEPTNUMBER = Purchase.FPURCHASEDEPTNUMBER,
                                    FXQD = _item.FXQD,
                                    FCREATORID = Purchase.FCREATORID,
                                    FName = Purchase.FName,
                                    FDate = Purchase.FDate,
                                    FDeliveryDate = Purchase.FDeliveryDate,
                                    F_QIMB_NOTE = Purchase.F_QIMB_NOTE,
                                    FNOTE = Purchase.FNOTE,
                                    FPURCHASEQTY = Purchase.FPURCHASEQTY,
                                    FJOINQTY = Purchase.FJOINQTY
                                });
                                //更新采购订单
                                //sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount = isnull(FPODemandPlanCount,0)+ '{Purchase.FQTY}' where FENTRYID = {Purchase.FENTRYID}");
                                //扣除日计划明细已被分配的数量
                                _item.NeedQty -= _NeedQty;
                                //扣除当前行对应采购订单数量
                                Purchase.FQTY = 0;
                            }
                        }
                        if (NeedQty > 0)
                        {
                            sql = $"INSERT INTO JIT_TLPLANERROR(HROGID,HUSERID,HWORKSHOPID,HDAYPLANID,HDAYPLANENTRYID,HMATERIALID,HQTY,HTYPE,HERRORTYPE) VALUES({fPrdOrgId},{user},{fProWorkShopId},{_item.FID},{_item.FENTRYID},{_item.FMATERIALID},{NeedQty},0,1) ";
                            sqlList.Add(sql);
                        }
                    }
                }
                //供应商,提料日期,生产车间,采购员 åˆ†ç»„
                var PODemandPlanList = PODemandPlanTemp.GroupBy(p => new { p.PurchseFNUMBER, p.FHMASTERDATE, p.FWORKSHOPNUMBER, p.FCREATORID }).Select(x => new PODemandPlanTemp { PurchseFNUMBER = x.Key.PurchseFNUMBER, FHMASTERDATE = x.Key.FHMASTERDATE, FWORKSHOPNUMBER = x.Key.FWORKSHOPNUMBER, FCREATORID = x.Key.FCREATORID }).ToList();
                LogService.Write("提料计划重算 ï¼Œæ•°æ®å‡†å¤‡å®Œæˆï¼Œä¿å­˜åˆ°Model实体 ç”¨æ—¶ï¼š" + sw.Elapsed + "总行数:" + PODemandPlanTemp.Count);
                int tlmmm = 0;
                JArray FinalyResult = new JArray();
                foreach (var item in PODemandPlanList)
                {
                    tlmmm++;
                    DateTime date = item.FHMASTERDATE;
                    long HSettleCurrId = 1;//货币 é»˜è®¤æœ¬åœ°äººæ°‘币
                    var dataSup= oCN.RunProcReturn(@"select * from Gy_Supplier p
                    inner join  AIS20230129011339..t_BD_Supplier fp on p.HNumber=fp.FNUMBER and p.HUSEORGID=fp.FUSEORGID
                    where FNUMBER='" + item.PurchseFNUMBER + "' and HUSEORGID ='"+ fPrdOrgId + "'", "Gy_Supplier");
                    long HSupplierID = dataSup.Tables[0].Rows.Count == 0 ? 0 : long.Parse(dataSup.Tables[0].Rows[0]["HItemID"].ToString()); //供应商
                    var dataUser = oCN.RunProcReturn("select Czymc from gy_czygl where Czybm = '" + user + "'", "gy_czygl");
                    string HMaker = dataUser.Tables[0].Rows.Count == 0 ? "" : dataUser.Tables[0].Rows[0][0].ToString();//制单人
                    string HUpDater = dataUser.Tables[0].Rows.Count == 0 ? "" : dataUser.Tables[0].Rows[0][0].ToString();//修改人
                    var dataOrg= oCN.RunProcReturn(@"select HItemID from Xt_ORGANIZATIONS o
                    inner join  AIS20230129011339..T_ORG_ORGANIZATIONS fo on o.HNumber=fo.FNUMBER
                    where FNUMBER='" + PODemandPlanTemp[0].FORGNumber + "'  and HItemID ='" + fPrdOrgId + "'", "Xt_ORGANIZATIONS");
                    long HPURCHASEORGID = dataOrg.Tables[0].Rows.Count == 0 ? 0 : long.Parse(dataOrg.Tables[0].Rows[0]["HItemID"].ToString()); //采购组织
                    string PurchseFNUMBER = item.PurchseFNUMBER;
                    string FWorkshopNumber = item.FWORKSHOPNUMBER;
                    string FCreatorID = item.FCREATORID;
                    var HInterID= DBUtility.ClsPub.CreateBillID("4608", ref DBUtility.ClsPub.sExeReturnInfo);
                    var HBillNo = DBUtility.ClsPub.CreateBillCode("4608", ref DBUtility.ClsPub.sExeReturnInfo, true);
                    //主表
                    oCN.RunProc("insert into JIT_Cg_PODemandPlanBillMain(HInterID,HBillNo,HYear,HPeriod,HBillType" +
                                ",HBillSubType,HDate,HBillStatus,HMaker,HMakeDate" +
                                ",HSubORGID ,HAddress,HPURCHASEORGID,HSupplierID ,HSettleCurrId" +
                                ",HRemark,HExplanation,HUpDater,HUpDateDate)" +
                               $"values({HInterID}, '{HBillNo}', {DateTime.Now.Year}, {DateTime.Now.Month}, '4608'" +
                               $", '4608','{date}',1, '{HMaker}',GETDATE()," +
                               $"{HPURCHASEORGID},'',{HPURCHASEORGID}, {HSupplierID}, {HSettleCurrId}" +
                               $",'','','{HUpDater}',getdate())");
                    JArray Fentity = new JArray();
                    List<PODemandPlanTemp> _PODemandPlanList = PODemandPlanTemp.Where(x => x.FHMASTERDATE == date && x.PurchseFNUMBER == PurchseFNUMBER && x.FWORKSHOPNUMBER == FWorkshopNumber && x.FCREATORID == FCreatorID).ToList();
                    int i = 0;
                    foreach (var _item in _PODemandPlanList)
                    {
                        i++;
                        var dataSet = oCN.RunProcReturn(@"select m.* from Gy_Material m
                        inner join  AIS20230129011339..T_BD_MATERIAL fm on m.HNumber = fm.FNUMBER and m.HUSEORGID=fm.FUSEORGID
                        where FNUMBER='" + _item.FNumber + "'  and HUSEORGID ='" + fPrdOrgId + "'", "Gy_Material");
                        string HMaterID = "0"; //物料
                        string HMaterModel = ""; //物料代码
                        string HMaterName = ""; //物料名称
                        if (dataSet.Tables[0].Rows.Count != 0)
                        {
                            HMaterID = dataSet.Tables[0].Rows[0]["HItemID"].ToString(); //物料
                            HMaterModel = dataSet.Tables[0].Rows[0]["HNumber"].ToString(); //物料代码
                            HMaterName = dataSet.Tables[0].Rows[0]["HName"].ToString(); //物料名称
                        }
                        decimal HQty = _item.FQty; //数量
                        long HSourceInterID = _item.FID; //日计划工单FID
                        long HSourceEntryID = _item.FENTRYID;//日计划工单FENTRYID
                        string HSourceBillNo = _item.FBILLNO; //生产订单号
                        string HSourceBillType = ""; //日计划工单类型
                        DateTime HDayPlanDate = _item.OLDDATE; // å·¥å•生产日期
                        decimal HRelationQty = _item.PurchseFqty; // å…³è”数量
                        double HFixleadTime = _item.FFIXLEADTIME; // æå‰æœŸ
                        dataOrg = oCN.RunProcReturn(@"select HItemID from Xt_ORGANIZATIONS o
                    inner join  AIS20230129011339..T_ORG_ORGANIZATIONS fo on o.HNumber=fo.FNUMBER
                    where FNUMBER='" + _item.FORGNumber + "'  and HItemID ='" + fPrdOrgId + "'", "Xt_ORGANIZATIONS");
                        long HPURCHASEORGIDSub = dataOrg.Tables[0].Rows.Count == 0 ? 0 : long.Parse(dataOrg.Tables[0].Rows[0]["HItemID"].ToString()); // é‡‡è´­ç»„织
                        long HPOOrderInterID = _item.PurchseFID; // é‡‡è´­è®¢å•内码
                        long HPOOrderEntryID = _item.PurchseFentryID; // é‡‡è´­è®¢å•子内码
                        string HPOOrderBillNo = _item.PurchseFBillNo; // é‡‡è´­è®¢å•号
                        string HErpClsID = _item.FErpClsID; // ç‰©æ–™å±žæ€§
                        long HUnitID = 10101; // è®¡é‡å•位  å…ˆæŒ‰ç…§æœ¬åœ°æ¥  é»˜è®¤ Pcs
                        string HSeOrderBillNo = _item.FXQD; // é”€å”®è®¢å•号   éœ€æ±‚单号
                        string HOrderEmpID = _item.FCREATORID; // é‡‡è´­å‘˜
                        DateTime HPOOrderBillDate = _item.FDate; // é‡‡è´­è®¢å•单据日期
                        DateTime HPOOrderBillDeliveryDate = _item.FDeliveryDate; // é‡‡è´­è®¢å•交货日期
                        string HPOOrderBillRemark = _item.F_QIMB_NOTE; // é‡‡è´­è®¢å•摘要
                        string HPOOrderBillNote = _item.FNOTE; // é‡‡è´­è®¢å•表体备注
                        string HDayPlanBillNo = _item.FDAYPLANBILLNO; // æ—¥è®¡åˆ’工单号
                         dataSet = oCN.RunProcReturn(@"select HItemID from Gy_Department d
                        inner join  AIS20230129011339..T_BD_DEPARTMENT fd on d.HNumber = fd.FNUMBER
                        where FNUMBER='" + _item.FWORKSHOPNUMBER + "'  and HUSEORGID ='" + fPrdOrgId + "'", "Gy_Department");
                        string HWorkShopID = dataSet.Tables[0].Rows.Count == 0 ? "0" : dataSet.Tables[0].Rows[0][0].ToString(); // ç”Ÿäº§è½¦é—´
                        dataSet = oCN.RunProcReturn(@"select HItemID from Gy_Department d
                        inner join  AIS20230129011339..T_BD_DEPARTMENT fd on d.HNumber = fd.FNUMBER
                        where FNUMBER='" + _item.FPURCHASEDEPTNUMBER + "'  and HUSEORGID ='" + fPrdOrgId + "'", "Gy_Department");
                        string HPurchaseDeptID = dataSet.Tables[0].Rows.Count == 0 ? "0" : dataSet.Tables[0].Rows[0][0].ToString(); // é‡‡è´­éƒ¨é—¨
                        decimal HPURCHASEQTY = _item.FPURCHASEQTY; // é‡‡è´­è®¢å•数量
                        decimal HJoinQty = _item.FJOINQTY; // é‡‡è´­è®¢å•关联数量
                        oCN.RunProc("insert into JIT_Cg_PODemandPlanBillSub(HInterID,HEntryID,HLaterReason,HMaterID,HMaterName" +
                           ", HMaterModel, HUnitID, HErpClsID, HQty, HRemark" +
                           ", HPURCHASEORGID, HStatus, HFixleadTime, HDayPlanBillNo, HSourceInterID" +
                           ", HSourceEntryID, HSourceBillNo, HSourceBillType, HWorkShopID, HDayPlanDate" +
                           ", HRelationQty1, HPOOrderInterID, HPOOrderEntryID, HPOOrderBillNo, HPOOrderBillSEQ" +
                           ", HWWOrderInterID, HWWOrderEntryID, HWWOrderBillNo, HPurchaseDeptID, HCloseTypeSub" +
                           ", HCloseMan, HEntryCloseDate, HSendQty, HReciveQty, HCloseStatus" +
                           ", HRemoveQty, HSeOrderBillNo, HUnReciveQty, HPOOrderBillDate, HPOOrderBillDeliveryDate" +
                           ", HPOOrderBillRemark, HPOOrderBillNote)" +
                           $"values({HInterID}, {i}, '', {(HMaterID == null ? "0" : HMaterID)}, '{HMaterName}'" +
                           $", '{HMaterModel}', {HUnitID}, '{HErpClsID}', {HQty}, ''" +
                           $", {HPURCHASEORGIDSub}, '', {HFixleadTime}, '{HDayPlanBillNo}', {HSourceInterID}" +
                           $", {HSourceEntryID}, '{HSourceBillNo}', '{HSourceBillType}', {HWorkShopID}, '{HDayPlanDate}'" +
                           $", {HRelationQty}, {HPOOrderInterID},{HPOOrderEntryID}, '{HPOOrderBillNo}',0" +
                           $",0,0, '',{HPurchaseDeptID}, '0'" +
                           $", '','',0,0, '0'" +
                           $",0, '{HSeOrderBillNo}',0, '{HPOOrderBillDate}', '{HPOOrderBillDeliveryDate}'" +
                           $", '{HPOOrderBillRemark}', '{HPOOrderBillNote}')");
                    }
                }
                if (tlmmm == PODemandPlanList.Count)
                {
                    oCN.Commit();
                    objJsonResult.code = "1";
                    objJsonResult.count = 1;
                    objJsonResult.Message = "运算成功!";
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                else
                {
                    oCN.RollBack();//事务回滚
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = "运算失败!";
                    objJsonResult.data = null;
                    return objJsonResult;
                }
            }
            catch (Exception e)
            {
                LogService.Write("操作失败:" + e.Message.ToString());
                oCN.RollBack();//事务回滚
                objJsonResult.code = "0";
                objJsonResult.count = 0;
                objJsonResult.Message = "Exception!" + e.Message.ToString();
                objJsonResult.data = null;
                return objJsonResult;
            }
        }
        #endregion
        #region ç”Ÿäº§æ—¥è®¡åˆ’平台 é”å®š
        [Route("JIT_DayPlanPlatFormBill/JIT_DayPlanPlatFormBillHLockedDay")]
        [HttpGet]
@@ -1217,31 +2041,67 @@
        #region ç”Ÿäº§æ—¥è®¡åˆ’平台 ç”Ÿäº§è®¢å•查询
        [Route("JIT_DayPlanPlatFormBill/JIT_ICMOBillList")]
        [HttpGet]
        public object JIT_ICMOBillList(string hmainid, string HEntryID)
        public object JIT_ICMOBillList(string hmainid)
        {
            try
            {
                DataSet dt = new DataSet();
                oCN.RunProc("exec h_p_ICMOBillList_PrimarySubTable");
                ds = oCN.RunProcReturn($"select * from  ##ICMOBillList where æºå•主内码 in({hmainid}) and  æºå•子内码 in({HEntryID})", "##ICMOBillList");
                for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
                var list = hmainid.Split(',');
                List<DataTable> listdt = new List<DataTable>();
                DataTable dtable = new DataTable("dt");
                for (int i = 0; i < list.Length; i++)
                {
                    dt = oCN.RunProcReturn($"select * from  h_v_JIT_Sc_WorkBillSortBillList where æºå•主内码 in({ds.Tables[0].Rows[i]["源单主内码"].ToString()}) and  æºå•子内码 in({ds.Tables[0].Rows[i]["源单子内码"].ToString()})", "h_v_JIT_Sc_WorkBillSortBillList");
                    var listEvery = list[i].Split('_');
                    ds = oCN.RunProcReturn($"exec h_p_ICMOBillList_PrimarySubTable '{listEvery[0]}','{listEvery[1]}'", "h_p_ICMOBillList_PrimarySubTable");
                    var dt = oCN.RunProcReturn($"select * from  h_v_JIT_Sc_WorkBillSortBillList where æºå•主内码 in({ds.Tables[0].Rows[0]["源单主内码"].ToString()}) and  æºå•子内码 in({ds.Tables[0].Rows[0]["源单子内码"].ToString()})", "h_v_JIT_Sc_WorkBillSortBillList");
                    if (dt.Tables[0].Rows.Count > 0)
                    {
                        objJsonResult.code = "0";
                        objJsonResult.count = 0;
                        objJsonResult.Message = "生产明细行重复,重复的生产订单号:"+ ds.Tables[0].Rows[i]["生产订单号"].ToString()+",明细行号:"+ ds.Tables[0].Rows[i]["生产订单明细行号"].ToString();
                        objJsonResult.Message = "生产明细行重复,重复的生产订单号:" + ds.Tables[0].Rows[i]["生产订单号"].ToString() + ",明细行号:" + ds.Tables[0].Rows[i]["生产订单明细行号"].ToString();
                        objJsonResult.data = null;
                        return objJsonResult;
                    }
                    if (i == 0)
                    {
                        //添加列名
                        for (int j = 0; j < ds.Tables[0].Columns.Count; j++)
                        {
                            dtable.Columns.Add(ds.Tables[0].Columns[j].ToString());
                        }
                    }
                    listdt.Add(ds.Tables[0]);
                }
                //获取集合数据
                for (int i = 0; i < listdt.Count; i++)
                {
                    DataRow row = dtable.NewRow();
                    for (int j = 0; j < listdt[i].Columns.Count; j++)
                    {
                        if (listdt[i].Columns[j].ColumnName == "计划数量")
                        {
                            row[j] = double.Parse(listdt[i].Rows[0][j].ToString()).ToString();
                        }
                        else
                        {
                            row[j] = listdt[i].Rows[0][j].ToString();
                        }
                    }
                    dtable.Rows.Add(row);
                }
                //添加动态日期
                for (int j = 1; j <= 31; j++)
                {
                    dtable.Columns.Add(DateTime.Now.AddDays(j - 1).ToString("yyyy-MM-dd"), typeof(Int32));
                }
                objJsonResult.code = "1";
                objJsonResult.count = 1;
                objJsonResult.Message = "Sucess!";
                objJsonResult.data = ds.Tables[0];
                objJsonResult.data = dtable;
                return objJsonResult;
            }
            catch (Exception e)