快乐的昕的电脑
2025-10-22 330481e48b742be6c465b543035c2424dd9b311d
调试
已修改1个文件
65 ■■■■ 文件已修改
Services/MesOrderStaManager.cs 65 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Services/MesOrderStaManager.cs
@@ -109,43 +109,48 @@
        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)
@@ -155,9 +160,9 @@
            {
                var ts = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
                Db.Updateable<MesQaItemsDetect02>()
                    .SetColumns(s => s.Remeke == $"工控机于{ts}自动创建的首检单({previousState})")
                    .Where(s => s.Id == latestFirst.Id)
                    .ExecuteCommand();
                  .SetColumns(s => s.Remeke == $"工控机于{ts}自动创建的首检单({previousState})")
                  .Where(s => s.Id == latestFirst.Id)
                  .ExecuteCommand();
            }
            if (previousState.Contains("不合格"))
@@ -165,24 +170,18 @@
        }
        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>()
                    .SetColumns(s => s.Remeke == $"工控机于{ts}首检结果:{latestResult}")
                    .Where(s => s.Id == latestFirst.Id)
                    .ExecuteCommand();
                  .SetColumns(s => s.Remeke == $"工控机于{ts}首检结果:{latestResult}")
                  .Where(s => s.Id == latestFirst.Id)
                  .ExecuteCommand();
            }
        }
        // 报工锚点逻辑
        // 报工锚点逻辑保持
        var mesReporting = Db.Queryable<MesReporting>()
            .Where(s => s.BillNo == womdaa.Daa001)
            .OrderByDescending(s => s.Id)
@@ -230,7 +229,7 @@
        };
        Db.Insertable<MesAnchors>(eAnchors).ExecuteCommand();
        // 合格且送检时间 >= 调机开始时间 => 写调机完成与开工时间
        // 合格写开工/调机完成
        if (!string.IsNullOrEmpty(entity.MaShoutTime)
            && DateTime.TryParse(entity.MaShoutTime, out var sjTime)
            && DateTime.TryParse(entity.MaStartTime, out var startTime)
@@ -248,7 +247,6 @@
            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)
@@ -259,6 +257,7 @@
            .ExecuteCommand() > 0;
    }
    /// <summary>
    ///     初始化工单状态
    /// </summary>