From c9481ef82ebf4095605f68695a1d02a252d33ff3 Mon Sep 17 00:00:00 2001 From: xwt <2740516069@qq.com> Date: 星期五, 27 六月 2025 16:54:34 +0800 Subject: [PATCH] 破坏实验添加 --- StandardInterface/MES.Service/service/QC/LljService.cs | 283 ++++++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 261 insertions(+), 22 deletions(-) diff --git a/StandardInterface/MES.Service/service/QC/LljService.cs b/StandardInterface/MES.Service/service/QC/LljService.cs index 1a3d6c4..b7a7f6f 100644 --- a/StandardInterface/MES.Service/service/QC/LljService.cs +++ b/StandardInterface/MES.Service/service/QC/LljService.cs @@ -1,10 +1,12 @@ 锘縰sing System.Data; +using System.Xml; using Masuit.Tools; using MES.Service.DB; using MES.Service.Dto.service; using MES.Service.Modes; using MES.Service.util; using SqlSugar; +using Tea.Utils; using DbType = System.Data.DbType; @@ -22,23 +24,36 @@ var totalCount = 0; - //var itemIds = GetQaItem(db, queryObj.createUser); - - var pageList = db.Queryable<LtsLlj>() + var pageList = db.Queryable<LtsLlj, IqcBefore, SysUser, + IqcBeforeFrom, SysUser, SysUser>((a, b, + e, f, g, i) => + new JoinQueryInfos(JoinType.Left, a.ItemId == b.ItemId, + JoinType.Left, a.CreateBy == e.Fcode, + JoinType.Left, f.Id == b.Pid, + JoinType.Left, f.Sid == Convert.ToDecimal(g.Fid), + JoinType.Left, f.CheckUser == i.Fcode + )) .WhereIF( StringUtil.IsNotNullOrEmpty(queryObj.result) && "鏈畬鎴�".Equals(queryObj.result), - a => a.FcheckResu == null) + (a, b, + e, f, g, i) => a.FcheckResu == null) .WhereIF( StringUtil.IsNotNullOrEmpty(queryObj.result) && !"鏈畬鎴�".Equals(queryObj.result), - a => a.FcheckResu != null) - .WhereIF(id > 0, a => a.Id == id) + (a, b, + e, f, g, i) => a.FcheckResu != null) + .WhereIF(id > 0, (a, b, + e, f, g, i) => a.Id == id) + .WhereIF(queryObj.createUser != "PL017" && queryObj.UserIndex == "0", (a, b, + e, f, g, i) => (g.Fcode == queryObj.createUser || i.Fcode == queryObj.createUser || + (g.Fcode == null && i.Fcode == null)))//鍒ゆ柇姝ゅ崟鐨勬楠屽憳锛屾垨鑰呮楠屼负绌哄氨鏄剧ず姝ゅ崟鎹� //鍔犵瓫閫夋潯浠�,鏍规嵁渚涘簲鍟嗭紝鐗╂枡缂栫爜锛岀墿鏂欏悕绉版悳绱� //.WhereIF(queryObj.SearchValue!=null && queryObj.SearchValue!="", (a) => a.SuppName == queryObj.SearchValue|| a.ItemName == queryObj.SearchValue || a.ItemNo == queryObj.SearchValue ) .WhereIF(!string.IsNullOrEmpty(queryObj.SearchValue), - a => a.SuppName.ToLower() + (a, b, + e, f, g, i) => a.SuppName.ToLower() .Contains(queryObj.SearchValue.ToLower()) || a.ItemName.ToLower() .Contains(queryObj.SearchValue.ToLower()) @@ -47,11 +62,23 @@ || a.LotNo.ToLower() .Contains(queryObj.SearchValue.ToLower()) || a.ReleaseNo.ToLower() + .Contains(queryObj.SearchValue.ToLower()) + || a.ItemModel.ToLower() .Contains(queryObj.SearchValue.ToLower())) - .OrderByDescending(a => a.Id) - .ToPageList(queryObj.PageIndex, queryObj.Limit, ref totalCount); + // .OrderByDescending((a, b, + .OrderBy ((a, b, + e, f, g, i) => a.Id) + //.Select((a, b, + // e, f, g, i) => new LtsLlj + // { + // //UserName = g.Fname, + // //UserName = (i.Fname!=null ||i.Fname!="") ? i.Fname : g.Fname, + // UserName = i.Fname != null || i.Fname != "" ? i.Fname : g.Fname, + // CreateUserName = e.Fname + // }, true) + .ToPageList(queryObj.PageIndex, queryObj.Limit, ref totalCount); - + var emergencyValues = pageList.Select(item => item.EMERGENCY).ToList(); return (pageList, totalCount); } @@ -63,9 +90,9 @@ /// <param name="quantity"></param> /// <param name="releaseNo"></param> /// <returns></returns> - public string[] SetItems(string itemNo, - decimal quantity, string releaseNo) + public string[] SetItems(decimal itemNo, decimal quantity, string releaseNo) { + // 瀹氫箟杈撳嚭鍙傛暟 var outputResult = new SugarParameter("o_Result", null, DbType.Int32, ParameterDirection.Output, @@ -78,8 +105,8 @@ // 瀹氫箟杈撳叆鍙傛暟 var parameters = new List<SugarParameter> { - new("P_RELEASE_NO", releaseNo, - DbType.String, ParameterDirection.Input), + new("P_RELEASE_NO", releaseNo, DbType.String, ParameterDirection.Input), + new("P_ITEM_ID", itemNo, DbType.String, ParameterDirection.Input), outputResult, outputMessage }; @@ -88,7 +115,7 @@ // 浣跨敤 SqlSugar 鎵ц瀛樺偍杩囩▼ db.Ado.ExecuteCommand( - "BEGIN PRC_QA_ITEM_INSERT_BTN(:P_RELEASE_NO, :o_Result, :o_Msg); END;", + "BEGIN PRC_QA_ITEM_INSERT_BTN(:P_RELEASE_NO,:P_ITEM_ID, :o_Result, :o_Msg); END;", parameters.ToArray()); // 鑾峰彇杈撳嚭鍙傛暟鐨勫�� @@ -100,6 +127,182 @@ return msg; } + //绱ф�ユ斁琛� + //public string[] EmergencyRelease(int id) + //{ + // var db = SqlSugarHelper.GetInstance(); + + + // int emergencyStatus = db.Queryable<MesQaItemsDetect01>() + // .Where(t => t.Id == id) + // .Select(t => t.EMERGENCY) + // .First(); + + // if (emergencyStatus != 0) + // { + // return new string[] { "1", "闈炵揣鎬ョ姸鎬侊紝鏃犳硶鎵ц绱ф�ユ斁琛�" }; + // } + + + // var outputResult = new SugarParameter("PO_RESULT", null, + // DbType.Int32, ParameterDirection.Output, 4000); + + // var outputMessage = new SugarParameter("PO_MSG", null, + // DbType.String, ParameterDirection.Output, 4000); + + // var parameters = new List<SugarParameter> + //{ + // new("P_ID", id, DbType.Int32, ParameterDirection.Input), + // outputResult, + // outputMessage + //}; + + // db.Ado.ExecuteCommand( + // "BEGIN prc_MES_QA_ITEMS_update1(:P_ID, :PO_RESULT, :PO_MSG); END;", + // parameters.ToArray()); + + // var lotNo1 = db.Queryable<MesQaItemsDetect01>() + // .Where(t => t.Id == id) + // .Select(t => t.LotNo1) + // .First(); + + // var resultValue = outputResult.Value?.ToString(); + // var messageValue = outputMessage.Value?.ToString(); + // return new string[] { resultValue, messageValue, lotNo1?.ToString() ?? "" }; + //} + + //public string[] WithdrawEmergencyRelease(int id) + //{ + // var db = SqlSugarHelper.GetInstance(); + + + // int emergencyStatus = db.Queryable<MesQaItemsDetect01>() + // .Where(t => t.Id == id) + // .Select(t => t.EMERGENCY) + // .First(); + + // if (emergencyStatus != 0) + // { + // return new string[] { "1", "闈炵揣鎬ョ姸鎬侊紝鏃犻渶鎾ゅ洖" }; + // } + + // var outputResult = new SugarParameter("PO_RESULT", null, + // DbType.Int32, ParameterDirection.Output, 4000); + + // var outputMessage = new SugarParameter("PO_MSG", null, + // DbType.String, ParameterDirection.Output, 4000); + + // var parameters = new List<SugarParameter> + //{ + // new("P_ID", id, DbType.Int32, ParameterDirection.Input), + // outputResult, + // outputMessage + //}; + + // db.Ado.ExecuteCommand( + // "BEGIN prc_MES_QA_ITEMS_update2(:P_ID, :PO_RESULT, :PO_MSG); END;", + // parameters.ToArray()); + + // var lotNo1 = db.Queryable<MesQaItemsDetect01>() + // .Where(t => t.Id == id) + // .Select(t => t.LotNo1) + // .First(); + + + // var resultValue = outputResult.Value?.ToString(); + // var messageValue = outputMessage.Value?.ToString(); + // return new string[] { resultValue, messageValue, lotNo1?.ToString() ?? "" }; + //} + + + + + + public string[] EmergencyRelease(int id) + { + var db = SqlSugarHelper.GetInstance(); + + + int emergencyStatus = db.Queryable<MesQaItemsDetect01>() + .Where(t => t.Id == id) + .Select(t => t.EMERGENCY) + .First(); + + if (emergencyStatus != 0) + { + return new string[] { "1", "闈炵揣鎬ョ姸鎬侊紝鏃犳硶鎵ц绱ф�ユ斁琛�" }; + } + + + var outputResult = new SugarParameter("PO_RESULT", null, + DbType.Int32, ParameterDirection.Output, 4000); + + var outputMessage = new SugarParameter("PO_MSG", null, + DbType.String, ParameterDirection.Output, 4000); + + var parameters = new List<SugarParameter> + { + new("P_ID", id, DbType.Int32, ParameterDirection.Input), + outputResult, + outputMessage + }; + + db.Ado.ExecuteCommand( + "BEGIN prc_MES_QA_ITEMS_update1(:P_ID, :PO_RESULT, :PO_MSG); END;", + parameters.ToArray()); + + var lotNo1 = db.Queryable<MesQaItemsDetect01>() + .Where(t => t.Id == id) + .Select(t => t.LotNo1) + .First(); + + var resultValue = outputResult.Value?.ToString(); + var messageValue = outputMessage.Value?.ToString(); + return new string[] { resultValue, messageValue, lotNo1?.ToString() ?? "" }; + } + + public string[] WithdrawEmergencyRelease(int id) + { + var db = SqlSugarHelper.GetInstance(); + + + int emergencyStatus = db.Queryable<MesQaItemsDetect01>() + .Where(t => t.Id == id) + .Select(t => t.EMERGENCY) + .First(); + + if (emergencyStatus != 0) + { + return new string[] { "1", "闈炵揣鎬ョ姸鎬侊紝鏃犻渶鎾ゅ洖" }; + } + + var outputResult = new SugarParameter("PO_RESULT", null, + DbType.Int32, ParameterDirection.Output, 4000); + + var outputMessage = new SugarParameter("PO_MSG", null, + DbType.String, ParameterDirection.Output, 4000); + + var parameters = new List<SugarParameter> + { + new("P_ID", id, DbType.Int32, ParameterDirection.Input), + outputResult, + outputMessage + }; + + db.Ado.ExecuteCommand( + "BEGIN prc_MES_QA_ITEMS_update2(:P_ID, :PO_RESULT, :PO_MSG); END;", + parameters.ToArray()); + + var lotNo1 = db.Queryable<MesQaItemsDetect01>() + .Where(t => t.Id == id) + .Select(t => t.LotNo1) + .First(); + + + var resultValue = outputResult.Value?.ToString(); + var messageValue = outputMessage.Value?.ToString(); + return new string[] { resultValue, messageValue, lotNo1?.ToString() ?? "" }; + } private string ExtractSubstring(string input, char startChar, char endChar) { @@ -192,7 +395,9 @@ a.FreQty, a.CheckQyt, a.FcheckResu, - a.FcheckItemDesc + a.FcheckItemDesc, + a.Funit, + a.Meom }).Select((a, b) => new MesQaItemsDetectDetail5 { Id = a.Id, @@ -213,7 +418,9 @@ FenterQty = SqlFunc.AggregateCount(b.Id), FcheckResu = a.FcheckResu, // FcheckItemDesc = a.FcheckItemDesc - FcheckItemDesc = a.FspecRequ + FcheckItemDesc = a.FspecRequ, + Funit = a.Funit, + Meom = a.Meom, }).ToList(); } @@ -294,8 +501,8 @@ return commit; }); - - var isNull = db.Queryable<MesQaItemsDetectDetail5>() + //5.20xwt淇敼灏嗘洿鏂颁富琛ㄦ楠岀粨鏋滃瓧娈垫斁鍦↖qcQaSubmit鏂规硶涓� + /*var isNull = db.Queryable<MesQaItemsDetectDetail5>() .Where(s => s.ReleaseNo == detail.ReleaseNo && s.FcheckResu == null) .Count(); @@ -333,7 +540,7 @@ .SetColumns(s => s.LastupdateDate == DateTime.Now) .Where(s => s.ReleaseNo == detail.ReleaseNo) .ExecuteCommand(); - }); + });*/ // if (FcheckResu.Equals("涓嶅悎鏍�")) //鑷姩鐢熸垚鍏ュ簱妫�寮傚父瀵圭瓥 /// saveDetect02(detail.Id, detail.CreateBy); @@ -475,6 +682,7 @@ return db.Updateable<MesQaItemsDetect01>() .SetColumns(it => it.FngDesc == dto.Remarks) //SetColumns鏄彲浠ュ彔鍔犵殑 鍐�2涓氨2涓瓧娈佃祴鍊� + .SetColumns(it => it.PHSY == dto.PHSY)//鐮村潖瀹為獙鏁� .Where(it => it.ReleaseNo == dto.releaseNo) .ExecuteCommand(); }); @@ -486,8 +694,11 @@ return SqlSugarHelper.UseTransactionWithOracle(db => { return db.Updateable<MesQaItemsDetectDetail5>() - .SetColumns(it => - it.Funit == dto.Remarks) //SetColumns鏄彲浠ュ彔鍔犵殑 鍐�2涓氨2涓瓧娈佃祴鍊� + .SetColumns(it => new MesQaItemsDetectDetail5 + { + Funit = dto.Remarks, + Meom = dto.Meom + }) .Where(it => it.Id == dto.pid) .ExecuteCommand(); }); @@ -559,6 +770,34 @@ if ("1".Equals(resultValue)) throw new Exception(messageValue); + var sum = db.Queryable<MesQaItemsDetectDetail5>() + .Where(s => s.ReleaseNo == dto.releaseNo).Count(); + + if (sum == 0) return true; + + var icount = db.Queryable<MesQaItemsDetectDetail5>() + .Where(s => s.ReleaseNo == dto.releaseNo && s.FcheckResu == "鍚堟牸") + .Count(); + + var FcheckResu = "涓嶅悎鏍�"; + + if (sum == icount) + FcheckResu = "鍚堟牸"; + + var sysUser = db.Queryable<SysUser>() + .Where(s => s.Fcode == dto.userNo).First(); + + SqlSugarHelper.UseTransactionWithOracle(db => + { + return db.Updateable<MesQaItemsDetect01>() + .SetColumns(s => s.FcheckResu == FcheckResu) + .SetColumns(s => s.FcheckDate == DateTime.Now) + .SetColumns(s => s.FcheckBy == sysUser.Fname) + .SetColumns(s => s.LastupdateBy == dto.userNo) + .SetColumns(s => s.LastupdateDate == DateTime.Now) + .Where(s => s.ReleaseNo == dto.releaseNo) + .ExecuteCommand(); + }); return true; } catch (Exception ex) -- Gitblit v1.9.3