| | |
| | | } |
| | | } |
| | | if (dsll.Any()) |
| | | { |
| | | foreach (var r in dsll) |
| | | { |
| | | foreach (var rows in r.Value.GroupBy(x => x.N_ROW).OrderBy(x => x.Key)) |
| | |
| | | if (arloclist.Any()) |
| | | { |
| | | if (EdnRarea == "YWLWJJB")//纸箱无菌接驳区 |
| | | // InworkLock = true; |
| | | //else InworkLock = false; |
| | | //if (od.S_ZZ_AREA == "YWLWJJB") |
| | | // InworkLock = true; |
| | | //else InworkLock = false; |
| | | //if (od.S_ZZ_AREA == "YWLWJJB") |
| | | { |
| | | if (InworkLock) |
| | | continue; |
| | |
| | | LogHelper.Info($"查起点有多少同品种的物料 开始"); |
| | | var ca = Expressionable.Create<Location, LocCntrRel, CntrItemRel>(); |
| | | ca.And((o, p, t) => o.N_CURRENT_NUM > 0 && o.S_LOCK_STATE == "无" && t.S_ITEM_CODE == cir1.S_ITEM_CODE && t.S_ITEM_NAME == cir1.S_ITEM_NAME && t.S_CJ_NAME == cir1.S_CJ_NAME && o.S_AREA_CODE == "YWLRGDD" && p.S_TYPE == _clrel0.S_TYPE); |
| | | var lstCanOutL = dbll.Queryable<Location>().InnerJoin<LocCntrRel>((o, p) => o.S_LOC_CODE == p.S_LOC_CODE).InnerJoin<CntrItemRel>((o, p, t) => p.S_CNTR_CODE == t.S_CNTR_CODE).Where(ca.ToExpression()).Includes(e => e.LocCntrRel, p => p.CntrItemRel).ToList(); |
| | | var lstCanOutL = dbll.Queryable<Location>().InnerJoin<LocCntrRel>((o, p) => o.S_LOC_CODE == p.S_LOC_CODE).InnerJoin<CntrItemRel>((o, p, t) => p.S_CNTR_CODE == t.S_CNTR_CODE).Where(ca.ToExpression()).ToList(); |
| | | LogHelper.Info($"起点要入CD的有多少托盘数量为{lstCanOutL.Count()}"); |
| | | //判断终点排能入多少 少于入库托盘数则多开一排 EndMum |
| | | var EndMum = dbll.Queryable<Location>().Where(l => l.S_AREA_CODE == EdnRarea && l.N_CURRENT_NUM == 0 && l.S_LOCK_STATE == "无" && inlockLis.Select(e => e.N_ROW).ToList().Contains(l.N_ROW)).ToList(); |
| | |
| | | } |
| | | } |
| | | } |
| | | else if (InworkLock) InworkLock = false; |
| | | } |
| | | else if (InworkLock) |
| | | { |
| | | InworkLock = false; |
| | | } |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | |
| | | public int Row { get; set; } |
| | | |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 原物料纸箱出库 |
| | | /// AB区物料不足自动转运 |
| | | /// </summary> |
| | | public static void AutoRun13TSJ() |
| | | public static void ZdzyABArea() |
| | | { |
| | | Action<YWLWorkOrder> _sAB没物料或者余量不足开始触发跟根据自动转运_名字越长越好 = (od) => |
| | | try |
| | | { |
| | | LogHelper.Info($"AutoRun13TSJ{od.SQL_WorkNo}对应工单的{od.S_ROW} 物料数量不足。触发转运。"); |
| | | // 先看是否有到该库区的转运任务。 |
| | | var zxs = LocationHelper.GetList<YWLZXtake>(X => X.S_ZX_STATE == "执行" && X.S_END_AREA == od.S_ROW); |
| | | //1.查看物料是否匹配。 |
| | | var itemTRUN = zxs.Any(x => x.S_ITEM_CODE == od.SQL_ItemCode && x.S_ITEM_NAME == od.SQL_ItemName && x.S_CJ_NAME == od.S_CJ_NAME); |
| | | if (itemTRUN) |
| | | { //有到该库区的 物料转运任务了。 不需要继续了 。 |
| | | |
| | | LogHelper.Info($"AutoRun13TSJ{od.SQL_WorkNo}已经存在转运了无需触发转运。"); |
| | | return; |
| | | } |
| | | //人工转运没指定物料,我会自动写回转运单 物料数据。 |
| | | |
| | | //找CD 区 哪里有这个物料。 |
| | | Dictitems TrunStart = null; |
| | | foreach (var area in CDlist) |
| | | var chi = new SqlHelper<object>().GetInstance(); |
| | | var newDb = chi.CopyNew(); |
| | | foreach (var PLC in Settings.GetDeviceInfoList().FindAll(X => X.deviceType == 13 && X.enable == 1)) |
| | | { |
| | | if (dsi.TryGetValue(area, out var dictitems1)) |
| | | string pline = PLC.deviceName; |
| | | if (PLC.deviceName.Contains("T2")) |
| | | pline = "T2提升机-纸箱"; |
| | | |
| | | var orkOrd = LocationHelper.GetList<YWLWorkOrder>(x => x.SQL_PLineNo == pline && x.WorkType == 6 && x.SQL_State == "执行中"); |
| | | if (orkOrd.Any()) |
| | | { |
| | | var arearowsloc = LocationHelper.GetAreaNormalLocList(area); |
| | | foreach (var d in dictitems1.FindAll(x => x.ItemCode == od.SQL_ItemCode && x.ItemName == od.SQL_ItemName && x.S_CJ_NAME == od.S_CJ_NAME)) |
| | | foreach (var od in orkOrd) |
| | | { |
| | | if (arearowsloc.Exists(x => x.N_ROW == d.Row)) |
| | | var loclist = LocationHelper.GetLocList(x => x.S_AREA_CODE == od.S_ROW); |
| | | //查询可用货位有多少 |
| | | List<string> Ky = new List<string>() { "无", "出库锁", "入库锁" }; |
| | | var loclistK = loclist.FindAll(x => Ky.Contains(x.S_LOCK_STATE)).Count(); |
| | | var count = loclist.FindAll(x => x.N_CURRENT_NUM > 0 && x.S_LOCK_STATE == "无").Sum(x => x.N_CURRENT_NUM); |
| | | LogHelper.Info("AutoRun13TSJ" + $"od.S_ROW 出库余量判断是否需要转运。-{count}< 总共能用的货位数{loclistK} -7"); |
| | | if (count <= loclistK - 7) |
| | | { |
| | | TrunStart = d; |
| | | break; |
| | | LogHelper.Info($"AutoRun13TSJ{od.SQL_WorkNo}对应工单的{od.S_ROW} 物料数量不足。触发转运。"); |
| | | // 先看是否有到该库区的转运任务。 |
| | | var zxs = LocationHelper.GetList<YWLZXtake>(X => X.S_ZX_STATE == "执行" && X.S_END_AREA == od.S_ROW); |
| | | |
| | | //1.查看物料是否匹配。 |
| | | var itemTRUN = zxs.Any(x => x.S_ITEM_CODE == od.SQL_ItemCode && x.S_ITEM_NAME == od.SQL_ItemName && x.S_CJ_NAME == od.S_CJ_NAME); |
| | | if (itemTRUN) |
| | | { //有到该库区的 物料转运任务了。 不需要继续了 。 |
| | | |
| | | LogHelper.Info($"AutoRun13TSJ{od.SQL_WorkNo}已经存在转运了无需触发转运。"); |
| | | return; |
| | | } |
| | | //人工转运没指定物料,我会自动写回转运单 物料数据。 |
| | | |
| | | //找CD 区 哪里有这个物料。 |
| | | Dictitems TrunStart = new Dictitems(); |
| | | foreach (var area in CDlist) |
| | | { |
| | | //var ca = Expressionable.Create<Location, LocCntrRel, CntrItemRel>(); |
| | | |
| | | //ca.And((o, p, t) => o.S_AREA_CODE == area && o.N_CURRENT_NUM > 0 && o.S_LOCK_STATE == "无" && t.S_ITEM_CODE == od.SQL_ItemCode && t.S_ITEM_NAME == od.SQL_ItemName && t.S_CJ_NAME == od.S_CJ_NAME); |
| | | var lstCanOutL = newDb.Queryable<Location>().InnerJoin<LocCntrRel>((o, p) => o.S_LOC_CODE == p.S_LOC_CODE).InnerJoin<CntrItemRel>((o, p, t) => p.S_CNTR_CODE == t.S_CNTR_CODE).Where((o, p, t) => o.S_AREA_CODE == area && o.N_CURRENT_NUM > 0 && o.S_LOCK_STATE == "无" && t.S_ITEM_CODE == od.SQL_ItemCode && t.S_ITEM_NAME == od.SQL_ItemName && t.S_CJ_NAME == od.S_CJ_NAME).ToList(); |
| | | List<string> CRk = new List<string>() { "出库锁", "入库锁" }; |
| | | var EndMum = newDb.Queryable<Location>().Where(l => l.S_AREA_CODE == area && CRk.Contains(l.S_LOCK_STATE)).ToList(); |
| | | var RowLock = EndMum.GroupBy(e => e.N_ROW).Select(f => f.First()).ToList(); |
| | | foreach (var item in RowLock) |
| | | { |
| | | lstCanOutL.RemoveAll(e => e.N_ROW == item.N_ROW); |
| | | } |
| | | if (lstCanOutL.Count() > 0) |
| | | { |
| | | var LstCan = newDb.Queryable<LocCntrRel>().Where(a => lstCanOutL.Select(e => e.S_LOC_CODE).ToList().Contains(a.S_LOC_CODE)).ToList(); |
| | | var loc = lstCanOutL.Find(e => e.S_LOC_CODE == LstCan.OrderBy(c => c.T_CREATE).FirstOrDefault().S_LOC_CODE); |
| | | TrunStart.area = area; |
| | | TrunStart.Row = loc.N_ROW; |
| | | } |
| | | //if (dsi.TryGetValue(area, out var dictitems1)) |
| | | //{ |
| | | |
| | | // var arearowsloc = LocationHelper.GetAreaNormalLocList(area); |
| | | // foreach (var d in dictitems1.FindAll(x => x.ItemCode == od.SQL_ItemCode && x.ItemName == od.SQL_ItemName && x.S_CJ_NAME == od.S_CJ_NAME)) |
| | | // { |
| | | // if (arearowsloc.Exists(x => x.N_ROW == d.Row)) |
| | | // { |
| | | // TrunStart = d; |
| | | // break; |
| | | // } |
| | | // } |
| | | //} |
| | | } |
| | | LogHelper.Info($"ZdzyABArea{od.SQL_WorkNo}触发转运。转运来源是{JsonConvert.SerializeObject(TrunStart)}"); |
| | | if (TrunStart?.area != null) |
| | | WCSHelper.Do(db => |
| | | { |
| | | db.Insertable(new YWLZXtake |
| | | { |
| | | S_START_AREA = TrunStart.area, |
| | | N_START_ROW = TrunStart.Row, |
| | | S_END_AREA = od.S_ROW, |
| | | S_ZX_STATE = "执行", |
| | | S_ITEM_CODE = od.SQL_ItemCode, |
| | | S_ITEM_NAME = od.SQL_ItemName, |
| | | S_CJ_NAME = od.S_CJ_NAME, |
| | | S_ZZ_AREA = (od.S_ROW == "YWLAQWJ" ? "YWLWJJB" : od.S_ROW) |
| | | }).ExecuteCommand(); |
| | | }); |
| | | |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | LogHelper.Info($"AutoRun13TSJ{od.SQL_WorkNo}触发转运。转运来源是{JsonConvert.SerializeObject(TrunStart)}"); |
| | | if (TrunStart != null) |
| | | WCSHelper.Do(db => |
| | | { |
| | | db.Insertable(new YWLZXtake |
| | | { |
| | | S_START_AREA = TrunStart.area, |
| | | N_START_ROW = TrunStart.Row, |
| | | S_END_AREA = od.S_ROW, |
| | | S_ZX_STATE = "执行", |
| | | S_ITEM_CODE = od.SQL_ItemCode, |
| | | S_ITEM_NAME = od.SQL_ItemName, |
| | | S_CJ_NAME = od.S_CJ_NAME, |
| | | S_ZZ_AREA = (od.S_ROW == "YWLAQWJ" ? "YWLWJJB" : od.S_ROW) |
| | | }).ExecuteCommand(); |
| | | }); |
| | | }; |
| | | |
| | | //var TaskSiggg = Settings.GetTimeStamp(); |
| | | //var list = new List<string>() { "YWLAQWJ", "YWLBQWJ", "YWLCQSX", "YWLDQWJ" }; |
| | | //var WorkOrder = new List<YWLWorkOrder>(); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | |
| | | LogHelper.Info($"ZdzyABArea 触发转运 报错:{ex.Message}"); |
| | | } |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 原物料纸箱出库 |
| | | /// </summary> |
| | | public static void AutoRun13TSJ() |
| | | { |
| | | //Action<YWLWorkOrder> _sAB没物料或者余量不足开始触发跟根据自动转运_名字越长越好 = (od) => |
| | | //{ |
| | | // LogHelper.Info($"AutoRun13TSJ{od.SQL_WorkNo}对应工单的{od.S_ROW} 物料数量不足。触发转运。"); |
| | | // // 先看是否有到该库区的转运任务。 |
| | | // var zxs = LocationHelper.GetList<YWLZXtake>(X => X.S_ZX_STATE == "执行" && X.S_END_AREA == od.S_ROW); |
| | | // //1.查看物料是否匹配。 |
| | | // var itemTRUN = zxs.Any(x => x.S_ITEM_CODE == od.SQL_ItemCode && x.S_ITEM_NAME == od.SQL_ItemName && x.S_CJ_NAME == od.S_CJ_NAME); |
| | | // if (itemTRUN) |
| | | // { //有到该库区的 物料转运任务了。 不需要继续了 。 |
| | | |
| | | // LogHelper.Info($"AutoRun13TSJ{od.SQL_WorkNo}已经存在转运了无需触发转运。"); |
| | | // return; |
| | | // } |
| | | // //人工转运没指定物料,我会自动写回转运单 物料数据。 |
| | | |
| | | // //找CD 区 哪里有这个物料。 |
| | | // Dictitems TrunStart = null; |
| | | // foreach (var area in CDlist) |
| | | // { |
| | | // if (dsi.TryGetValue(area, out var dictitems1)) |
| | | // { |
| | | // var arearowsloc = LocationHelper.GetAreaNormalLocList(area); |
| | | // foreach (var d in dictitems1.FindAll(x => x.ItemCode == od.SQL_ItemCode && x.ItemName == od.SQL_ItemName && x.S_CJ_NAME == od.S_CJ_NAME)) |
| | | // { |
| | | // if (arearowsloc.Exists(x => x.N_ROW == d.Row)) |
| | | // { |
| | | // TrunStart = d; |
| | | // break; |
| | | // } |
| | | // } |
| | | // } |
| | | // } |
| | | |
| | | // LogHelper.Info($"AutoRun13TSJ{od.SQL_WorkNo}触发转运。转运来源是{JsonConvert.SerializeObject(TrunStart)}"); |
| | | // if (TrunStart != null) |
| | | // WCSHelper.Do(db => |
| | | // { |
| | | // db.Insertable(new YWLZXtake |
| | | // { |
| | | // S_START_AREA = TrunStart.area, |
| | | // N_START_ROW = TrunStart.Row, |
| | | // S_END_AREA = od.S_ROW, |
| | | // S_ZX_STATE = "执行", |
| | | // S_ITEM_CODE = od.SQL_ItemCode, |
| | | // S_ITEM_NAME = od.SQL_ItemName, |
| | | // S_CJ_NAME = od.S_CJ_NAME, |
| | | // S_ZZ_AREA = (od.S_ROW == "YWLAQWJ" ? "YWLWJJB" : od.S_ROW) |
| | | // }).ExecuteCommand(); |
| | | // }); |
| | | //}; |
| | | foreach (var PLC in Settings.GetDeviceInfoList().FindAll(X => X.deviceType == 13 && X.enable == 1)) |
| | | { |
| | | string pline = PLC.deviceName; |
| | |
| | | if (locs.Find(x => x.N_CURRENT_NUM > 0) != null) //拆垛有货 不判断 |
| | | continue; |
| | | can = true; |
| | | |
| | | //var source1 = orkOrd.FirstOrDefault(); |
| | | //foreach (var item in list) |
| | | //{ |
| | | // YWLWorkOrder source = new YWLWorkOrder(); |
| | | // source.SQL_PLineNo = source1.SQL_PLineNo; |
| | | // source.FuLe_PLine_No = source1.FuLe_PLine_No; |
| | | // source.SQL_LinkLineNO = source1.SQL_LinkLineNO; |
| | | // source.SQL_Area = item; |
| | | // source.SQL_UsingNow = source1.SQL_UsingNow; |
| | | // source.SQL_State = source1.SQL_State; |
| | | // source.SQL_WorkNo = source1.SQL_WorkNo; |
| | | // source.SQL_ItemCode = source1.SQL_ItemCode; |
| | | // source.SQL_ItemName = source1.SQL_ItemName; |
| | | // source.SQL_charge = source1.SQL_charge; |
| | | // source.SQL_Total = source1.SQL_Total; |
| | | // source.SQL_PLAN_END = source1.SQL_PLAN_END; |
| | | // source.SQL_Modify_TIme = source1.SQL_Modify_TIme; |
| | | // source.OutNum = source1.OutNum; |
| | | // source.WorkType = source1.WorkType; |
| | | // source.MidArea = source1.MidArea; |
| | | // source.TagOver = source1.TagOver; |
| | | // source.TagOverTime = source1.TagOverTime; |
| | | // source.S_BQ_TRAY_TYPE = source1.S_BQ_TRAY_TYPE; |
| | | // source.S_CJ_NAME = source1.S_CJ_NAME; |
| | | // source.S_ROW = item; |
| | | // WorkOrder.Add(source); |
| | | //} |
| | | } |
| | | |
| | | orkOrd = orkOrd.FindAll(x => x.OutNum > 0 && DateTime.Now.Subtract(x.SQL_Modify_TIme ?? DateTime.Now).TotalSeconds > 10); |
| | |
| | | //检测指定库区的物料排总数量 |
| | | if (dsi.TryGetValue(od.S_ROW, out var dictitems1)) |
| | | { |
| | | var rows = dictitems1.Select(x => x.Row).Distinct(); |
| | | var loclist = LocationHelper.GetLocList(x => x.S_AREA_CODE == od.S_ROW && rows.Contains(x.N_ROW)); |
| | | var count = loclist.FindAll(x => x.N_CURRENT_NUM > 0 && x.S_LOCK_STATE == "无").Sum(x => x.N_CURRENT_NUM); |
| | | LogHelper.Info("AutoRun13TSJ" + $"od.S_ROW 出库余量判断是否需要转运。-{count}< 5"); |
| | | if (count < 5) |
| | | { |
| | | autoTurn = true; |
| | | _sAB没物料或者余量不足开始触发跟根据自动转运_名字越长越好(od); |
| | | } |
| | | //var rows = dictitems1.Select(x => x.Row).Distinct(); |
| | | //var loclist = LocationHelper.GetLocList(x => x.S_AREA_CODE == od.S_ROW && rows.Contains(x.N_ROW)); |
| | | ////查询可用货位有多少 |
| | | //List<string> Ky = new List<string>() { "无", "出库锁", "入库锁" }; |
| | | //var loclistK = loclist.FindAll(x => Ky.Contains(x.S_LOCK_STATE)).Count(); |
| | | //var count = loclist.FindAll(x => x.N_CURRENT_NUM > 0 && x.S_LOCK_STATE == "无").Sum(x => x.N_CURRENT_NUM); |
| | | //LogHelper.Info("AutoRun13TSJ" + $"od.S_ROW 出库余量判断是否需要转运。-{count}< 总共能用的货位数{loclistK} -7"); |
| | | //if (count < loclistK - 7) |
| | | //{ |
| | | // autoTurn = true; |
| | | // _sAB没物料或者余量不足开始触发跟根据自动转运_名字越长越好(od); |
| | | //} |
| | | } |
| | | } |
| | | Location Endbit = null; |
| | |
| | | b = TaskProcess.CreateTransport(od.SQL_WorkNo, StartBit.S_LOC_CODE, jbbit, "原物料搬运-纸箱", crs, StartBit.N_CURRENT_NUM - crs.Count + 1, 1, crs.Count, PLC.taskPri, "", Endbit.S_LOC_CODE); |
| | | else |
| | | b = TaskProcess.CreateTransport(od.SQL_WorkNo, StartBit.S_LOC_CODE, Endbit.S_LOC_CODE, "原物料搬运-纸箱", crs, StartBit.N_CURRENT_NUM - crs.Count + 1, 1, crs.Count, PLC.taskPri); |
| | | |
| | | if (b) |
| | | { |
| | | var r = new RowLock { S_LOCK_SRC = od.SQL_ItemCode, T_LOCK_TIME = DateTime.Now, S_LOCK_STATE = "出库锁", S_AREA_CODE = StartBit.S_AREA_CODE, N_ROW = StartBit.N_ROW }; |
| | | var db = new SqlHelper<object>().GetInstance(); |
| | | od.TagOverTime = DateTime.Now; |
| | | od.TagOver = StartBit.S_AREA_CODE; |
| | | var ggf = db.Updateable(od).UpdateColumns(it => new { it.TagOverTime, it.TagOver }).ExecuteCommand(); |
| | | LogHelper.Info($"上提升机任务 更新工单的时间影响行数: {ggf}"); |
| | | |
| | | var r = new RowLock { S_LOCK_SRC = od.SQL_ItemCode, T_LOCK_TIME = DateTime.Now, S_LOCK_STATE = "出库锁", S_AREA_CODE = StartBit.S_AREA_CODE, N_ROW = StartBit.N_ROW }; |
| | | |
| | | //给终点锁定住 |
| | | if (od.S_ROW == "YWLCQSX" || od.S_ROW == "YWLDQWJ") |
| | | { |
| | |
| | | // } |
| | | //} |
| | | //else db.Insertable(r).ExecuteCommand(); |
| | | od.TagOverTime = DateTime.Now; |
| | | od.TagOver = StartBit.S_AREA_CODE; |
| | | db.Updateable(od).UpdateColumns(it => new { it.TagOverTime, it.TagOver }).ExecuteCommand(); |
| | | |
| | | //break; |
| | | } |
| | | } |
| | |
| | | } |
| | | } |
| | | } |
| | | else |
| | | { |
| | | _sAB没物料或者余量不足开始触发跟根据自动转运_名字越长越好(od); |
| | | } |
| | | //else |
| | | //{ |
| | | // _sAB没物料或者余量不足开始触发跟根据自动转运_名字越长越好(od); |
| | | //} |
| | | } |
| | | } |
| | | } |