| | |
| | | using HH.WCS.Mobox3.pinggao.models; |
| | | using HH.WCS.Mobox3.pinggao.api; |
| | | using HH.WCS.Mobox3.pinggao.models; |
| | | using HH.WCS.Mobox3.pinggao.util; |
| | | using HH.WCS.Mobox3.pinggao.wms; |
| | | using System; |
| | |
| | | using System.Reflection; |
| | | using System.Text; |
| | | using System.Threading.Tasks; |
| | | using static HH.WCS.Mobox3.pinggao.api.ApiModel; |
| | | |
| | | namespace HH.WCS.Mobox3.pinggao.core |
| | | { |
| | |
| | | //WMSHelper.GetWaitingSortingOrderList(); |
| | | |
| | | } |
| | | |
| | | //internal static async Task<SimpleResult> SendSap() |
| | | //{ |
| | | // var result = new SimpleResult(); |
| | | // LogHelper.Info($"下发sap "); |
| | | // var db = new SqlHelper<object>().GetInstance(); |
| | | // //获取配盘单 |
| | | // var list = db.Queryable<TN_Outbound_Order>().Where(a => a.S_CNTR_CODE == model.cntr_code).First(); ; |
| | | // try |
| | | // { |
| | | // foreach (var po in list) { |
| | | |
| | | // if (po.S_OUT_TYPE == "冲销出库") |
| | | // { |
| | | // result = await WmsSpaHelper.CXAddOutboundOrder(db, model.MaterList, model.arrival_no, model.cntr_code, start); |
| | | // } |
| | | // else |
| | | // if (po.S_OUT_TYPE == "出库")//普通出库 |
| | | // { |
| | | // LogHelper.Info($"S_OUT_TYPE{po.S_OUT_TYPE}"); |
| | | // result = await AddOutboundOrder(db, model.MaterList, model.arrival_no, model.cntr_code, start); |
| | | // } |
| | | // else if (po.S_OUT_TYPE == "计划外发料出库") |
| | | // { |
| | | // result = await jhwtlAddOutboundOrder(db, model.MaterList, model.arrival_no, model.cntr_code, start); |
| | | // } |
| | | // else if (po.S_OUT_TYPE == "成本中心出库") |
| | | // { |
| | | // result = await CBAddOutboundOrder(db, model.MaterList, model.arrival_no, model.cntr_code, start); |
| | | // } |
| | | |
| | | // } |
| | | |
| | | |
| | | // } |
| | | // catch (Exception ex) |
| | | // { |
| | | // LogHelper.Info($"配盘生成作业错误 {ex.Message}"); |
| | | // throw; |
| | | // } |
| | | // LogHelper.Info($"获取配盘数量 {list.Count}"); |
| | | //} |
| | | |
| | | |
| | | internal static void CheckDistributionCNTROrder() |
| | | { |
| | | LogHelper.Info($"配盘生成作业 "); |
| | |
| | | var lcr = db.Queryable<LocCntrRel>().Where(c => c.S_CNTR_CODE == item.S_CNTR_CODE).First(); |
| | | if (lcr != null) |
| | | { |
| | | var yxj = db.Queryable<TN_Outbound_Order>().Where(it => it.S_NO == item.S_BS_NO).First(); |
| | | |
| | | //起始库位 |
| | | var startloc = db.Queryable<Location>().Where(it => it.S_CODE == lcr.S_LOC_CODE).First(); |
| | | if (startloc != null)//&& |
| | |
| | | S_CODE = WMSHelper.GenerateTaskNo(), |
| | | S_START_LOC = item.S_LOC_CODE, |
| | | S_START_AREA = startloc.S_AREA_CODE, |
| | | N_PRIORITY = yxj.N_PRIORITY, |
| | | S_START_WH = startloc.S_WH_CODE, |
| | | S_END_LOC = endloc.S_CODE, |
| | | S_END_AREA = endloc.S_AREA_CODE, |
| | |
| | | } |
| | | |
| | | |
| | | |
| | | |
| | | internal static void podetailSend() |
| | | { |
| | | LogHelper.Info($"自动生成出库任务 "); |
| | | var db = new SqlHelper<object>().GetInstance(); |
| | | //获取入库明细单 |
| | | |
| | | var list = db.Queryable<TN_Inbound_Detail>().Where(a => a.N_B_STATE == 1).ToList(); |
| | | |
| | | |
| | | |
| | | var list = db.Queryable<TN_Center_Inbound_Detail>().ToList(); |
| | | try |
| | | { |
| | | foreach (var item in list) |
| | | { |
| | | var cir2 = db.Queryable<CGRels>().Where(a => a.S_ITEM_CODE == item.S_ITEM_CODE&&a.S_CNTR_TYPE=="半托").First(); |
| | | bool idadd = true; |
| | | var S_CNTR_CODE = ""; |
| | | if (cir2 != null) |
| | | var lcr = db.Queryable<LocCntrRel>() |
| | | .InnerJoin<CGRels>((l, c) => l.S_CNTR_CODE == c.S_CNTR_CODE) |
| | | .Where((l, c) => c.S_ITEM_CODE == item.S_ITEM_CODE && c.S_CNTR_TYPE == "半托") |
| | | .OrderByDescending((l, c) => l.T_CREATE) |
| | | .Select((l, c) => l).ToList() |
| | | .FirstOrDefault(); |
| | | S_CNTR_CODE = lcr.S_CNTR_CODE; |
| | | if (lcr != null) |
| | | { |
| | | S_CNTR_CODE=cir2.S_CNTR_CODE; |
| | | |
| | | var lcr = db.Queryable<LocCntrRel>().Where(c => c.S_CNTR_CODE == S_CNTR_CODE).First(); |
| | | if (lcr != null) |
| | | //起始库位 |
| | | var startloc = db.Queryable<Location>().Where(it => it.S_CODE == lcr.S_LOC_CODE).First(); |
| | | var wsc = db.Queryable<WCSTask>().Where(it => it.S_CNTR_CODE == S_CNTR_CODE && it.S_TYPE.Contains("出库") && it.N_B_STATE < 3).First(); |
| | | if (wsc != null) |
| | | { |
| | | //起始库位 |
| | | var startloc = db.Queryable<Location>().Where(it => it.S_CODE == lcr.S_LOC_CODE).First(); |
| | | var wsc = db.Queryable<WCSTask>().Where(it => it.S_CNTR_CODE == S_CNTR_CODE && it.N_B_STATE < 3).First(); |
| | | if (wsc != null) |
| | | item.N_B_STATE = 2; |
| | | db.Updateable(item).UpdateColumns(it => new { it.N_B_STATE }).ExecuteCommand(); |
| | | } |
| | | else |
| | | { |
| | | if (startloc != null)//&& |
| | | { |
| | | item.N_B_STATE = 2; |
| | | db.Updateable(item).UpdateColumns(it => new { it.N_B_STATE }).ExecuteCommand(); |
| | | } |
| | | else |
| | | { |
| | | if (startloc != null)//&& |
| | | //终点货位 |
| | | var endloc = db.Queryable<Location>().Where(it => it.S_AREA_CODE == "QYQXHQ" && it.N_LOCK_STATE == 0 && it.N_CURRENT_NUM == 0).First(); |
| | | if (endloc != null) |
| | | { |
| | | //终点货位 |
| | | var endloc = db.Queryable<Location>().Where(it => it.S_AREA_CODE == "QYQXHQ" && it.N_LOCK_STATE == 0 && it.N_CURRENT_NUM == 0).First(); |
| | | |
| | | // var endloc = db.Queryable<Location>().Where(it => it.S_CODE == item.S_END_LOC).First(); |
| | | if (endloc != null) |
| | | var optask = new WMSTask |
| | | { |
| | | var optask = new WMSTask |
| | | S_CODE = WMSHelper.GenerateTaskNo(), |
| | | S_START_LOC = startloc.S_CODE, |
| | | S_START_AREA = startloc.S_AREA_CODE, |
| | | S_START_WH = startloc.S_WH_CODE, |
| | | S_END_LOC = endloc.S_CODE, |
| | | S_END_AREA = endloc.S_AREA_CODE, |
| | | S_END_WH = endloc.S_WH_CODE, |
| | | N_PRIORITY = 1, |
| | | S_TYPE = "半托出库", |
| | | N_TYPE = 2, |
| | | N_B_STATE = 0, |
| | | S_BS_NO = "", |
| | | S_CNTR_CODE = S_CNTR_CODE, |
| | | S_OP_DEF_NAME = item.S_BS_TYPE |
| | | }; |
| | | var res = db.Insertable(optask).ExecuteCommand() > 0; |
| | | if (res) |
| | | { |
| | | startloc.N_LOCK_STATE = 2; |
| | | startloc.S_LOCK_STATE = "出库锁"; |
| | | db.Updateable(startloc).UpdateColumns(it => new { it.S_LOCK_STATE, it.N_LOCK_STATE }).ExecuteCommand(); |
| | | var models = db.Queryable<Location>().Where(a => a.S_CODE == endloc.S_CODE).First(); |
| | | if (models != null && models.N_LOCK_STATE == 0) |
| | | { |
| | | S_CODE = WMSHelper.GenerateTaskNo(), |
| | | S_START_LOC = startloc.S_CODE, |
| | | S_START_AREA = startloc.S_AREA_CODE, |
| | | S_START_WH = startloc.S_WH_CODE, |
| | | S_END_LOC = endloc.S_CODE, |
| | | S_END_AREA = endloc.S_AREA_CODE, |
| | | S_END_WH = endloc.S_WH_CODE, |
| | | S_TYPE = "出库区", |
| | | N_TYPE = 2, |
| | | N_B_STATE = 0, |
| | | S_BS_NO = "", |
| | | S_CNTR_CODE = S_CNTR_CODE, |
| | | S_OP_DEF_NAME = item.S_BS_TYPE |
| | | }; |
| | | var res = db.Insertable(optask).ExecuteCommand() > 0; |
| | | if (res) |
| | | { |
| | | startloc.N_LOCK_STATE = 2; |
| | | startloc.S_LOCK_STATE = "出库锁"; |
| | | db.Updateable(startloc).UpdateColumns(it => new { it.S_LOCK_STATE, it.N_LOCK_STATE }).ExecuteCommand(); |
| | | LocationHelper.LockLoc(endloc.S_CODE, 1); |
| | | item.N_B_STATE = 2; |
| | | db.Updateable(item).UpdateColumns(it => new { it.N_B_STATE }).ExecuteCommand(); |
| | | |
| | | |
| | | models.N_LOCK_STATE = 1; |
| | | models.S_LOCK_STATE = Location.GetLockStateStr(1); |
| | | res = db.Updateable(models).UpdateColumns(it => new { it.N_LOCK_STATE, it.S_LOCK_STATE }).ExecuteCommand() > 0; |
| | | } |
| | | } |
| | | else |
| | | { |
| | | LogHelper.Info($"{item.S_BS_NO}配盘 库区AGVXHQ无空货位"); |
| | | item.N_B_STATE = 2; |
| | | db.Updateable(item).UpdateColumns(it => new { it.N_B_STATE }).ExecuteCommand(); |
| | | |
| | | |
| | | } |
| | | } |
| | | else |
| | | { |
| | | LogHelper.Info($"{item.S_BS_NO}配盘 库区无货位"); |
| | | idadd = false; |
| | | LogHelper.Info($" 库区AGVXHQ无空货位"); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | idadd = false; |
| | | LogHelper.Info($" 库区无货位"); |
| | | } |
| | | } |
| | | |
| | | } |
| | | else |
| | | { |
| | | LogHelper.Info($"配盘生成作业容器未绑定货位"); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | LogHelper.Info($"未找到物料{item.S_ITEM_CODE}对应的容器"); |
| | | idadd = false; |
| | | LogHelper.Info($"物料{item.S_ITEM_CODE}未找到容器对应的货位信息,请联系人工绑定关系"); |
| | | } |
| | | if (idadd) |
| | | { |
| | | db.Deleteable(item).ExecuteCommand(); |
| | | |
| | | } |
| | | } |
| | | |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | LogHelper.Info($"配盘生成作业错误 {ex.Message}"); |
| | | LogHelper.Info($"自动生成出库任务 {ex.Message}"); |
| | | throw; |
| | | } |
| | | LogHelper.Info($"获取配盘数量 {list.Count}"); |
| | | LogHelper.Info($"自动生成人物 {list.Count}"); |
| | | } |
| | | /// <summary> |
| | | /// 遍历分拣单明细创建出库作业 |
| | |
| | | S_END_AREA = endinfo.S_AREA_CODE, |
| | | S_END_WH = endinfo.S_WH_CODE, |
| | | S_SCHEDULE_TYPE = "NDC", |
| | | N_PRIORITY = a.N_PRIORITY, |
| | | //N_CNTR_COUNT = 1, |
| | | S_CNTR_CODE = a.S_CNTR_CODE, |
| | | }; |