| | |
| | | using Tiger.Model.Entitys.MES.Position; |
| | | using Apache.NMS.ActiveMQ.Commands; |
| | | using System.Security.Cryptography; |
| | | using System.Diagnostics; |
| | | |
| | | namespace Tiger.Business.MES |
| | | { |
| | |
| | | /// </summary> |
| | | /// <param name="input"></param> |
| | | /// <returns></returns> |
| | | public async Task<ApiAction> GetBasItem(GetBasItemInput input) |
| | | public ApiAction GetBasItem(U9C_MES_Input input) |
| | | { |
| | | var action = new ApiAction(); |
| | | Logger.Scheduler.Info($"物料信息开始同步。。。数据检查进行中。。。"); |
| | |
| | | Accuracy = (di["Accuracy"] ?? "").ToString(), |
| | | Remark = (di["Remark"] ?? "").ToString(), |
| | | Packaging = (di["Packaging"] ?? "").ToString(), |
| | | SapCode = (di["Code1"] ?? "").ToString(), |
| | | }; |
| | | itemExts.Add(extInfo); |
| | | } |
| | |
| | | } |
| | | Logger.Scheduler.Info($"物料信息存入实体中,总数:[{items.Count}]"); |
| | | db = Biz.Db; |
| | | var LastRun = await db.Queryable<SYS_PARAM>().Where(q => q.PRMG_CODE == "Interface_LastRun" && q.PARAM_CODE == "GetItem_LastRun").SingleAsync(); |
| | | LastRun.PARAM_VALUE = (input.endTime.ToDateTime() - DateTime.Now).TotalMinutes > 0 ? LastRun.PARAM_VALUE : input.endTime; |
| | | var dbTran = db.UseTran(() => |
| | | { |
| | | db.Storageable(LastRun, "U9C_MES_GetItem").ExecuteCommand(); |
| | | if (items.Any()) |
| | | { |
| | | if (items.Count > 150) |
| | | if (items.Count > 100) |
| | | { |
| | | db.Utilities.PageEach(items, 1000, pageList => |
| | | db.Utilities.PageEach(items, 100, pageList => |
| | | { |
| | | var y = db.Storageable(pageList, "U9C") |
| | | .WhereColumns(t => new { t.ID, t.GHOST_ROW }) |
| | | .ToStorage(); |
| | | y.BulkCopy(); |
| | | y.BulkUpdate(); |
| | | y.AsInsertable.ExecuteCommand(); |
| | | y.AsUpdateable.ExecuteCommand(); |
| | | }); |
| | | } |
| | | else |
| | | { |
| | | var s = db.Storageable(items, "U9C") |
| | | .WhereColumns(t => new { t.ID, t.GHOST_ROW }) |
| | | .ToStorage(); |
| | | s.AsInsertable.ExecuteCommand(); |
| | | s.AsUpdateable.ExecuteCommand(); |
| | | else { |
| | | var y = db.Storageable(items, "U9C") |
| | | .WhereColumns(t => new { t.ID, t.GHOST_ROW }) |
| | | .ToStorage(); |
| | | y.AsInsertable.ExecuteCommand(); |
| | | y.AsUpdateable.ExecuteCommand(); |
| | | } |
| | | } |
| | | if (itemExts.Any()) |
| | | { |
| | | if (itemExts.Count > 150) |
| | | if (itemExts.Count > 100) |
| | | { |
| | | db.Utilities.PageEach(itemExts, 1000, pageList => |
| | | { |
| | | var y = db.Storageable(pageList, "U9C") |
| | | .WhereColumns(t => new { t.ITEM_ID, t.GHOST_ROW }) |
| | | .ToStorage(); |
| | | y.BulkCopy(); |
| | | y.BulkUpdate(); |
| | | }); |
| | | db.Utilities.PageEach(itemExts, 100, pageList => |
| | | { |
| | | var y = db.Storageable(pageList, "U9C") |
| | | .WhereColumns(t => new { t.ITEM_ID, t.GHOST_ROW }) |
| | | .ToStorage(); |
| | | y.AsInsertable.ExecuteCommand(); |
| | | y.AsUpdateable.IgnoreColumns(x => x.ID).ExecuteCommand(); |
| | | }); |
| | | } |
| | | else |
| | | { |
| | |
| | | Logger.Scheduler.Error(action.Message); |
| | | } |
| | | Logger.Scheduler.Info($"物料信息存入数据库,总数:[{items.Count}]"); |
| | | action.Message = $"物料信息存入数据库,总数:[{items.Count}]"; |
| | | return action; |
| | | } |
| | | |
| | |
| | | db.Storageable(LastRun, "U9C_MES_GetWo").ExecuteCommand(); |
| | | if (items.Any()) |
| | | { |
| | | if (items.Count > 150) |
| | | if (items.Count > 100) |
| | | { |
| | | db.Utilities.PageEach(items, 1000, pageList => |
| | | db.Utilities.PageEach(items, 100, pageList => |
| | | { |
| | | var y = db.Storageable(pageList, "U9C") |
| | | .WhereColumns(t => new { t.ORDER_NO, t.GHOST_ROW }) |
| | | .ToStorage(); |
| | | y.BulkCopy(); |
| | | y.BulkUpdate(); |
| | | y.AsInsertable.ExecuteCommand(); |
| | | y.AsUpdateable.IgnoreColumns(x => x.ID).ExecuteCommand(); |
| | | }); |
| | | } |
| | | else |
| | |
| | | { |
| | | if (woList.Any()) |
| | | { |
| | | var s = _db.Storageable(woList, "U9C") |
| | | .WhereColumns(t => new { t.ORDER_NO, t.GHOST_ROW }) |
| | | .ToStorage(); |
| | | s.AsInsertable.ExecuteCommand(); |
| | | s.AsUpdateable.IgnoreColumns(x => x.ID).UpdateColumns(x => new { x.ROUTE_STATUS}).ExecuteCommand(); |
| | | _db.Updateable(woList, "U9C").UpdateColumns(x => new { x.ROUTE_STATUS }).ExecuteCommand(); |
| | | } |
| | | |
| | | }); |
| | |
| | | /// <param name="input"></param> |
| | | /// <returns></returns> |
| | | /// <exception cref="NotImplementedException"></exception> |
| | | public async Task<ApiAction> GetCustomer(GetCustomerInput input) |
| | | public ApiAction GetCustomer(U9C_MES_Input input) |
| | | { |
| | | var action = new ApiAction(); |
| | | Logger.Scheduler.Info($"客户信息开始同步。。。数据检查进行中。。。"); |
| | | Logger.Scheduler.Info($"{input.triggerDetail}"); |
| | | DbClient db = Biz.DataSource["YadaU9C"].Client; |
| | | var list = db.Queryable<dynamic>().AS("mes_Customer").Where("ModifiedOn > @startTime And ModifiedOn < @endTime", new { startTime = input.startTime, endTime = input.endTime }).ToList(); |
| | | var orgs = await Biz.Db.Queryable<SYS_ORGANIZATION>().ToListAsync(); |
| | | var orgs = Biz.Db.Queryable<SYS_ORGANIZATION>().ToList(); |
| | | List<BAS_CUSTOMER> items = new(); |
| | | if (list != null && list.Count > 0) |
| | | { |
| | |
| | | } |
| | | Logger.Scheduler.Info($"客户信息存入实体中,总数:[{items.Count}]"); |
| | | db = Biz.Db; |
| | | var LastRun = db.Queryable<SYS_PARAM>().Where(q => q.PRMG_CODE == "Interface_LastRun" && q.PARAM_CODE == "GetCust_LastRun").Single(); |
| | | LastRun.PARAM_VALUE = (input.endTime.ToDateTime() - DateTime.Now).TotalMinutes > 0 ? LastRun.PARAM_VALUE : input.endTime; |
| | | var dbTran = db.UseTran(() => |
| | | { |
| | | db.Storageable(LastRun, "U9C_MES_GetCustomer").ExecuteCommand(); |
| | | if (items.Any()) |
| | | { |
| | | if (items.Count > 150) |
| | | if (items.Count > 100) |
| | | { |
| | | db.Utilities.PageEach(items, 1000, pageList => |
| | | db.Utilities.PageEach(items, 100, pageList => |
| | | { |
| | | var y = db.Storageable(pageList, "U9C") |
| | | .WhereColumns(t => new { t.CUST_CODE, t.GHOST_ROW }) |
| | | .ToStorage(); |
| | | y.BulkCopy(); |
| | | y.BulkUpdate(); |
| | | y.AsInsertable.ExecuteCommand(); |
| | | y.AsUpdateable.IgnoreColumns(x => x.ID).ExecuteCommand(); |
| | | }); |
| | | } |
| | | else |
| | |
| | | Logger.Scheduler.Error(action.Message); |
| | | } |
| | | Logger.Scheduler.Info($"客户信息存入数据库,总数:[{items.Count}]"); |
| | | action.Message = $"客户信息存入数据库,总数:[{items.Count}]"; |
| | | return action; |
| | | } |
| | | |
| | |
| | | /// </summary> |
| | | /// <param name="input"></param> |
| | | /// <returns></returns> |
| | | public async Task<ApiAction> GetSupplier(GetSupplierInput input) |
| | | public ApiAction GetSupplier(U9C_MES_Input input) |
| | | { |
| | | var action = new ApiAction(); |
| | | Logger.Scheduler.Info($"供应商信息开始同步。。。数据检查进行中。。。"); |
| | | Logger.Scheduler.Info($"{input.triggerDetail}"); |
| | | DbClient db = Biz.DataSource["YadaU9C"].Client; |
| | | var list = db.Queryable<dynamic>().AS("mes_Supplier").Where("ModifiedOn > @startTime And ModifiedOn < @endTime", new { startTime = input.startTime, endTime = input.endTime }).ToList(); |
| | | var orgs = await Biz.Db.Queryable<SYS_ORGANIZATION>().ToListAsync(); |
| | | var orgs = Biz.Db.Queryable<SYS_ORGANIZATION>().ToList(); |
| | | List<BAS_SUPPLIER> items = new(); |
| | | if (list != null && list.Count > 0) |
| | | { |
| | |
| | | } |
| | | Logger.Scheduler.Info($"供应商信息存入实体中,总数:[{items.Count}]"); |
| | | db = Biz.Db; |
| | | var LastRun = db.Queryable<SYS_PARAM>().Where(q => q.PRMG_CODE == "Interface_LastRun" && q.PARAM_CODE == "Vender_LastTime").Single(); |
| | | LastRun.PARAM_VALUE = (input.endTime.ToDateTime() - DateTime.Now).TotalMinutes > 0 ? LastRun.PARAM_VALUE : input.endTime; |
| | | var dbTran = db.UseTran(() => |
| | | { |
| | | db.Storageable(LastRun, "U9C_MES_GetCustomer").ExecuteCommand(); |
| | | if (items.Any()) |
| | | { |
| | | if (items.Count > 150) |
| | | if (items.Count > 100) |
| | | { |
| | | db.Utilities.PageEach(items, 1000, pageList => |
| | | db.Utilities.PageEach(items, 100, pageList => |
| | | { |
| | | var y = db.Storageable(pageList, "U9C") |
| | | .WhereColumns(t => new { t.SUPP_CODE, t.GHOST_ROW }) |
| | | .ToStorage(); |
| | | y.BulkCopy(); |
| | | y.BulkUpdate(); |
| | | y.AsInsertable.ExecuteCommand(); |
| | | y.AsUpdateable.IgnoreColumns(x => x.ID).ExecuteCommand(); |
| | | }); |
| | | } |
| | | else |
| | |
| | | Logger.Scheduler.Error(action.Message); |
| | | } |
| | | Logger.Scheduler.Info($"供应商信息存入数据库,总数:[{items.Count}]"); |
| | | action.Message = $"供应商信息存入数据库,总数:[{items.Count}]"; |
| | | return action; |
| | | } |
| | | |
| | |
| | | /// </summary> |
| | | /// <param name="input"></param> |
| | | /// <returns></returns> |
| | | public async Task<ApiAction> GetCustBarCode(GetCustBarcodeInput input) |
| | | public ApiAction GetCustBarCode(U9C_MES_Input input) |
| | | { |
| | | var action = new ApiAction(); |
| | | Logger.Scheduler.Info($"客户条码信息开始同步。。。数据检查进行中。。。"); |
| | |
| | | { |
| | | if (di["MoDoc"] != null) |
| | | { |
| | | var _MES_WO = await Biz.Db.Queryable<BIZ_MES_WO>().Where(x => x.ORDER_NO == di["MoDoc"].ToString()).FirstAsync(); |
| | | var _MES_WO = Biz.Db.Queryable<BIZ_MES_WO>().Where(x => x.ORDER_NO == di["MoDoc"].ToString()).First(); |
| | | MES_CUST_SN snItem = new() |
| | | { |
| | | CUST_CODE = _MES_WO?.CUST_CODE ?? "", |
| | |
| | | } |
| | | Logger.Scheduler.Info($"客户条码信息存入实体中,总数:[{items.Count}]"); |
| | | db = Biz.Db; |
| | | var LastRun = db.Queryable<SYS_PARAM>().Where(q => q.PRMG_CODE == "Interface_LastRun" && q.PARAM_CODE == "GetCustBar_LastTime").Single(); |
| | | LastRun.PARAM_VALUE = (input.endTime.ToDateTime() - DateTime.Now).TotalMinutes > 0 ? LastRun.PARAM_VALUE : input.endTime; |
| | | var dbTran = db.UseTran(() => |
| | | { |
| | | db.Storageable(LastRun, "U9C_MES_GetCustomer").ExecuteCommand(); |
| | | if (items.Any()) |
| | | { |
| | | if (items.Count > 150) |
| | | if (items.Count > 100) |
| | | { |
| | | db.Utilities.PageEach(items, 1000, pageList => |
| | | db.Utilities.PageEach(items, 100, pageList => |
| | | { |
| | | var y = db.Storageable(pageList, "U9C") |
| | | .WhereColumns(t => new { t.CUST_SN, t.GHOST_ROW }) |
| | | .ToStorage(); |
| | | y.BulkCopy(); |
| | | y.BulkUpdate(); |
| | | y.AsInsertable.ExecuteCommand(); |
| | | y.AsUpdateable.IgnoreColumns(x => x.ID).ExecuteCommand(); |
| | | }); |
| | | } |
| | | else |
| | |
| | | Logger.Scheduler.Error(action.Message); |
| | | } |
| | | Logger.Scheduler.Info($"客户条码信息存入数据库,总数:[{items.Count}]"); |
| | | action.Message = $"客户条码信息存入数据库,总数:[{items.Count}]"; |
| | | return action; |
| | | } |
| | | |
| | | public ApiAction GetU9CBasWo(GetWoInput input) |
| | | public ApiAction GetU9CBasWo(U9C_MES_Input input) |
| | | { |
| | | var action = new ApiAction(); |
| | | Logger.Scheduler.Info($"工单信息开始同步。。。数据检查进行中。。。"); |
| | |
| | | CUST_PREFIX = di["OutBarHead"] == null ? "" : di["OutBarHead"].ToString(), |
| | | SALES_CONTRACT = di["Contracts"] == null ? "" : di["Contracts"].ToString(), |
| | | }; |
| | | if (!Biz.Db.Queryable<BIZ_MES_WO>().Any(x => x.ORDER_NO == woItem.ORDER_NO && (x.STATUS > BIZ_MES_WO.STATUSs.Init.GetValue() || x.ROUTE_STATUS > BIZ_MES_WO.ROUTE_STATUSs.WaitSet.GetValue()))) |
| | | if (!Biz.Db.Queryable<BIZ_MES_WO>().Any(x => x.ORDER_NO == woItem.ORDER_NO && x.STATUS > BIZ_MES_WO.STATUSs.Imported.GetValue())) |
| | | { |
| | | items.Add(woItem); |
| | | } |
| | |
| | | } |
| | | Logger.Scheduler.Info($"工单信息存入实体中,总数:[{items.Count}]"); |
| | | db = Biz.Db; |
| | | var LastRun = db.Queryable<SYS_PARAM>().Where(q => q.PRMG_CODE == "Interface_LastRun" && q.PARAM_CODE == "GetWo_LastRun").Single(); |
| | | LastRun.PARAM_VALUE = (input.endTime.ToDateTime() - DateTime.Now).TotalMinutes > 0 ? LastRun.PARAM_VALUE : input.endTime; |
| | | var dbTran = db.UseTran(() => |
| | | { |
| | | db.Storageable(LastRun, "U9C_MES_GetWo").ExecuteCommand(); |
| | | if (items.Any()) |
| | | { |
| | | if (items.Count > 150) |
| | | if (items.Count > 100) |
| | | { |
| | | db.Utilities.PageEach(items, 1000, pageList => |
| | | db.Utilities.PageEach(items, 100, pageList => |
| | | { |
| | | var y = db.Storageable(pageList, "U9C") |
| | | .WhereColumns(t => new { t.ORDER_NO, t.GHOST_ROW }) |
| | | .ToStorage(); |
| | | y.BulkCopy(); |
| | | y.BulkUpdate(); |
| | | y.AsInsertable.ExecuteCommand(); |
| | | y.AsUpdateable.IgnoreColumns(x => x.ID).ExecuteCommand(); |
| | | }); |
| | | } |
| | | else |