| | |
| | | var womdaa = Db.Queryable<Womdaa>().Where(s => s.Id == entity.OrderId).First(); |
| | | if (womdaa == null) throw new Exception("工单不存在"); |
| | | |
| | | // 当前数据库状态(用于对比送检时间是否变化) |
| | | var dbSta = Db.Queryable<MesOrderSta>().Where(s => s.Id == entity.Id).First(); |
| | | |
| | | // 行级锁防并发 |
| | | // 行级锁 |
| | | Db.Ado.ExecuteCommand("SELECT ID FROM WOMDAA WHERE DAA001 = :BILL_NO FOR UPDATE", |
| | | new SugarParameter("BILL_NO", womdaa.Daa001)); |
| | | |
| | | // 最新首检单 |
| | | // 最新首检 |
| | | var latestFirst = Db.Queryable<MesQaItemsDetect02>() |
| | | .Where(s => s.Aufnr == womdaa.Daa001 && s.Ftype == FirstCheckType && (s.Fcancel == null || s.Fcancel != "Y")) |
| | | .OrderBy(s => s.CreateDate, OrderByType.Desc) |
| | | .First(); |
| | | |
| | | var latestResult = latestFirst?.FcheckResu?.Trim(); |
| | | |
| | | // 送检时间是否变化(表示用户重新点击了送检呼叫) |
| | | var isShoutTimeChanged = !string.IsNullOrEmpty(entity.MaShoutTime) |
| | | && entity.MaShoutTime != dbSta?.MaShoutTime; |
| | | // ForceRebuild 可选扩展 |
| | | var forceRebuild = (entity as dynamic)?.ForceRebuild == true; |
| | | |
| | | // 可选:如果前端以后加 ForceRebuild,可在 DTO 中增加 bool? ForceRebuild |
| | | // var forceRebuild = (entity as dynamic)?.ForceRebuild == true; |
| | | |
| | | // 重建条件:首次 / 不合格且送检时间变化 |
| | | var needRebuild = latestFirst == null || |
| | | (string.Equals(latestResult, FirstCheckResultNG, StringComparison.OrdinalIgnoreCase) && isShoutTimeChanged); |
| | | // || forceRebuild; |
| | | // 立即重建条件:首次无单 或 最新结果 == 不合格 或 强制 |
| | | var needRebuild = latestFirst == null |
| | | || string.Equals(latestResult, FirstCheckResultNG, StringComparison.OrdinalIgnoreCase) |
| | | || forceRebuild; |
| | | |
| | | if (needRebuild) |
| | | { |
| | | var previousState = latestResult == null ? "首次创建" |
| | | : (latestResult == FirstCheckResultNG ? "不合格后重建" : "重建"); |
| | | : (latestResult == FirstCheckResultNG ? "不合格后立即重建" : "重建"); |
| | | |
| | | // 可选:保留旧记录,或标记旧记录作废(如果需要避免多条待检) |
| | | // 若要作废上一条不合格单:取消即可 |
| | | if (latestFirst != null && string.Equals(latestResult, FirstCheckResultNG, StringComparison.OrdinalIgnoreCase)) |
| | | { |
| | | Db.Updateable<MesQaItemsDetect02>() |
| | | .SetColumns(s => s.Fcancel == "Y") |
| | | .Where(s => s.Id == latestFirst.Id) |
| | | .ExecuteCommand(); |
| | | } |
| | | |
| | | // 调用存储过程创建新首检单 |
| | | Db.Ado.ExecuteCommand( |
| | | "BEGIN AUTOMATIC_IPQC_FIRST_CHECK(:BILL_NO); END;", |
| | | new SugarParameter("BILL_NO", womdaa.Daa001, System.Data.DbType.String)); |
| | | |
| | | // 重取最新首检单 |
| | | // 重新获取新建的首检单 |
| | | latestFirst = Db.Queryable<MesQaItemsDetect02>() |
| | | .Where(s => s.Aufnr == womdaa.Daa001 && s.Ftype == FirstCheckType && (s.Fcancel == null || s.Fcancel != "Y")) |
| | | .OrderBy(s => s.CreateDate, OrderByType.Desc) |
| | |
| | | } |
| | | else |
| | | { |
| | | // 不合格但送检时间未变化 => 提示重新送检 |
| | | if (latestFirst != null |
| | | && string.Equals(latestResult, FirstCheckResultNG, StringComparison.OrdinalIgnoreCase) |
| | | && !isShoutTimeChanged) |
| | | { |
| | | entity.remark = "上一首检不合格,请重新点击送检呼叫以生成新的首检单"; |
| | | } |
| | | else if (latestFirst != null) |
| | | // 不需要重建时仅写结果备注(若已有首检) |
| | | if (latestFirst != null && !string.IsNullOrEmpty(latestResult)) |
| | | { |
| | | var ts = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"); |
| | | Db.Updateable<MesQaItemsDetect02>() |
| | |
| | | } |
| | | } |
| | | |
| | | // 报工锚点逻辑 |
| | | // 报工锚点逻辑保持 |
| | | var mesReporting = Db.Queryable<MesReporting>() |
| | | .Where(s => s.BillNo == womdaa.Daa001) |
| | | .OrderByDescending(s => s.Id) |
| | |
| | | }; |
| | | Db.Insertable<MesAnchors>(eAnchors).ExecuteCommand(); |
| | | |
| | | // 合格且送检时间 >= 调机开始时间 => 写调机完成与开工时间 |
| | | // 合格写开工/调机完成 |
| | | if (!string.IsNullOrEmpty(entity.MaShoutTime) |
| | | && DateTime.TryParse(entity.MaShoutTime, out var sjTime) |
| | | && DateTime.TryParse(entity.MaStartTime, out var startTime) |
| | |
| | | entity.MaEndTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"); |
| | | } |
| | | |
| | | // 更新工单状态 |
| | | return Db.Updateable<MesOrderSta>() |
| | | .SetColumnsIF(entity.MaShoutTime != null, s => s.MaShoutTime == entity.MaShoutTime) |
| | | .SetColumnsIF(entity.MaStartTime != null, s => s.MaStartTime == entity.MaStartTime) |
| | |
| | | .ExecuteCommand() > 0; |
| | | } |
| | | |
| | | |
| | | /// <summary> |
| | | /// 初始化工单状态 |
| | | /// </summary> |