using System.Data; using System.Data.SqlClient; using System.Text; using Gs.Entity.QC; using Gs.Toolbox; using Gs.Toolbox.ApiCore.Abstract.Mvc; using Gs.Toolbox.ApiCore.Common.Mvc; using Gs.Toolbox.ApiCore.Group; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using System.Dynamic; using static Gs.Toolbox.UtilityHelper; namespace GS.QC.Service; [ApiGroup(ApiGroupNames.QC)] public class MesQaItemsDetect01Manager : Repository,IRomteService { private readonly IHttpContextAccessor _http; private readonly string _userCode, _userGuid, _orgFids; public MesQaItemsDetect01Manager(IHttpContextAccessor httpContextAccessor) { _http = httpContextAccessor; (_userCode, _userGuid, _orgFids) = UtilityHelper.GetUserGuidAndOrgGuid(_http); } #region CRUD /// /// 读取列表,支持分页 /// /// /// [RequestMethod(RequestMethods.POST)] public ReturnDto> GetListPage([FromBody] dynamic model) { int currentPage = model.currentPage; int everyPageSize = model.everyPageSize; string sortName = model.sortName; string keyWhere = model.keyWhere; SqlParameter[] parameters = { new("@inCurrentPage", currentPage), new("@inEveryPageSize", everyPageSize), new("@inSortName", sortName), new("@inSortOrder", ""), new("@inQueryWhere", keyWhere), new("@inFid", ""), new("@inP1", ""), new("@inP2", ""), new("@inP3", ""), new("@inP4", "") }; var dset = new DataSet(); var _pglist = new PageList { total = 0, everyPageSize = 0, pages = 0, list = new List() }; try { dset = DbHelperSQL.RunProcedure("iqc_detect01_lst", parameters, "0"); if (dset != null && dset.Tables.Count > 0 && dset.Tables[0].Rows.Count > 0) //有数据 { var intTotal = int.Parse(dset.Tables[1].Rows[0]["intTotal"].ToString()); var pages = intTotal % everyPageSize != 0 ? intTotal / everyPageSize + 1 : intTotal / everyPageSize; _pglist.total = intTotal; _pglist.everyPageSize = everyPageSize; _pglist.pages = pages; var _dy = dset.Tables[0].TableToDynamicList(); _pglist.list = _dy; } } catch (Exception ex) { LogHelper.Debug(ToString(), ex.Message); } return ReturnDto>.QuickReturn(_pglist, ReturnCode.Success, "读取成功"); } /// /// 读取 /// /// /// [RequestMethod(RequestMethods.POST)] public ReturnDto GetModel([FromBody] dynamic model) { string guid = model.guid.ToString(); dynamic m = new ExpandoObject(); m.list5 = new List(); SqlParameter[] parameters = { new("@inMainGuid", guid), new("@inP1", ""), new("@inP2", ""), new("@inP3", ""), new("@inP4", "") }; var dset = new DataSet(); try { dset = DbHelperSQL.RunProcedure("[iqc_detect01_get]", parameters, "0"); if (dset != null && dset.Tables.Count > 0 && dset.Tables[0].Rows.Count > 0) { var dr = dset.Tables[0].Rows[0]; m = dr.RowToDynamic(); var _tb = dset.Tables[1].TableToDynamicList(); m.list5 = _tb; } } catch (Exception ex) { LogHelper.Debug(ToString(), ex.Message); } if (m != null) return ReturnDto.QuickReturn(m, ReturnCode.Success, "读取成功!"); return ReturnDto.QuickReturn(m, ReturnCode.Default, "读取失败!"); } /// /// 读取 /// /// /// [RequestMethod(RequestMethods.POST)] public ReturnDto GetModel12([FromBody] dynamic model) { Guid guid = model.guid; string parentGuid = model.parentGuid; dynamic m = new ExpandoObject(); m.list = new List(); m.list2 = new List(); System.Text.StringBuilder sb = new StringBuilder(); sb.Append("select * from MES_QA_ITEMS_DETECT_DETAIL12 where parent_guid='" + guid + "' order by fstand asc"); sb.Append(" select d13.*,d5.fcheck_item as fcheckItemd5,d5.ybsl from MES_QA_ITEMS_DETECT_DETAIL13 d13 left join[dbo].[MES_QA_ITEMS_DETECT_DETAIL5] d5 on d13.parent_guid = d5.guid"); sb.Append(" where d13.parent_guid = '" + guid + "'"); sb.Append(" order by d13.fcheck_item asc"); try { DataSet dset = new DataSet(); dset = DbHelperSQL.Query(sb.ToString()); var _tb = dset.Tables[0].TableToDynamicList(); m.list = _tb; var _tb2 = dset.Tables[1].TableToDynamicList(); m.list2 = _tb2; } catch (Exception ex) { LogHelper.Debug(ToString(), "GetModel12 error:" + ex.Message); } if (m != null) return ReturnDto.QuickReturn(m, ReturnCode.Success, "读取成功!"); return ReturnDto.QuickReturn(m, ReturnCode.Default, "读取失败!"); } /// /// 重新加载检验项目 /// /// /// [RequestMethod(RequestMethods.POST)] public ReturnDto ReloadModel5( [FromBody] MesQaItemsDetect01 model) { int? rtnInt = (int)ReturnCode.Default; string _sbMsg = ""; using (var conn = new SqlConnection(DbHelperSQL.strConn)) { using (var cmd = new SqlCommand("iqc_detect01_reload", conn)) { try { conn.Open(); cmd.CommandType = CommandType.StoredProcedure; SqlParameter[] parameters = { new("@outMsg", SqlDbType.NVarChar, 300), new("@outSum", SqlDbType.Int), new("@inEdtUserGuid", _userGuid), new("@inOrderGuid", model.Guid), new("@inFieldName", ""), new("@inFieldValue", ""), new("@in1", ""), new("@in2", "") }; parameters[0].Direction = ParameterDirection.Output; parameters[1].Direction = ParameterDirection.Output; foreach (var parameter in parameters) cmd.Parameters.Add(parameter); cmd.ExecuteNonQuery(); _sbMsg = (parameters[0].Value.ToString()); rtnInt = int.Parse(parameters[1].Value.ToString()); } catch (Exception ex) { LogHelper.Debug(ToString(), "chk_iqc_detect01_reload error:" + ex.Message); _sbMsg = ("存储过程执行失败," + ex.Message); } finally { conn.Close(); } } } if (rtnInt > 0) return ReturnDto.QuickReturn(rtnInt, ReturnCode.Success, _sbMsg); return ReturnDto.QuickReturn(rtnInt, ReturnCode.Exception, _sbMsg); } /// /// 录入检验结果 /// /// /// [RequestMethod(RequestMethods.POST)] public ReturnDto EdtModel12([FromBody] dynamic model) { string inOrderGuid1 = model.inOrderGuid1; //这是检验单guid string inOrderGuid5 = model.inOrderGuid5; //这是抽样的guid string inP1 = model.inP1; //这是9,有可能是19,或者0k-19,或者ng-19 var _outMsg = ""; int? _outSum = -1; using (var conn = new SqlConnection(DbHelperSQL.strConn)) { using (var cmd = new SqlCommand("[iqc_detect01_panding]", conn)) { try { conn.Open(); cmd.CommandType = CommandType.StoredProcedure; SqlParameter[] parameters = { new("@outMsg", SqlDbType.NVarChar, 300), new("@outSum", SqlDbType.Int), new("@inEdtUserGuid", _userGuid), new("@inOrderGuid1", inOrderGuid1), new("@inOrderGuid5", inOrderGuid5), new("@inP1", inP1), }; parameters[0].Direction = ParameterDirection.Output; parameters[1].Direction = ParameterDirection.Output; foreach (var parameter in parameters) cmd.Parameters.Add(parameter); cmd.ExecuteNonQuery(); _outMsg = parameters[0].Value.ToString(); _outSum = int.Parse(parameters[1].Value.ToString()); } catch (Exception ex) { LogHelper.Debug(ToString(), "prc_iqc_panding error:" + ex.Message); _outMsg = ex.Message; _outSum = -1; } finally { conn.Close(); } } } if (_outSum <= 0) return ReturnDto.QuickReturn(_outSum, ReturnCode.Exception, _outMsg); return ReturnDto.QuickReturn(_outSum, ReturnCode.Success, _outMsg); } /// /// 增加或编辑到货单 /// /// /// [RequestMethod(RequestMethods.POST)] public ReturnDto EditModel([FromBody] dynamic model) { Guid? guid = model.guid; //到货单主键 string fngDesc = model.fngDesc; //备注 var _outMsg = ""; var _outSum = -1; using (var conn = new SqlConnection(DbHelperSQL.strConn)) { using (var cmd = new SqlCommand("[iqc_detect01_edt]", conn)) { try { conn.Open(); cmd.CommandType = CommandType.StoredProcedure; SqlParameter[] parameters = { new("@outMsg", SqlDbType.NVarChar, 300), new("@outSum", SqlDbType.Int), new("@inEdtUserGuid", _userGuid), new("@inOrderGuid", UtilityHelper.CheckGuid(guid) ? guid: DBNull.Value), new("@fngDesc", fngDesc), }; parameters[0].Direction = ParameterDirection.Output; parameters[1].Direction = ParameterDirection.Output; foreach (var parameter in parameters) cmd.Parameters.Add(parameter); cmd.ExecuteNonQuery(); _outMsg = parameters[0].Value.ToString(); _outSum = int.Parse(parameters[1].Value.ToString()); } catch (Exception ex) { LogHelper.Debug(ToString(), "chk_iqc_detect01_edt error:" + ex.Message); _outMsg = ex.Message; _outSum = -1; } finally { conn.Close(); } } } if (_outSum <= 0) return ReturnDto.QuickReturn(guid.ToString(), ReturnCode.Exception, _outMsg); return ReturnDto.QuickReturn(guid.ToString(), ReturnCode.Success, _outMsg); } #endregion #region 提交检验 /// /// 提交检验 /// /// /// [RequestMethod(RequestMethods.POST)] public ReturnDto EditModelSubmit([FromBody] dynamic mode) { string _guid = mode.guid; dynamic m = new ExpandoObject(); m.outSum = -1; m.outMsg = ""; using (var conn = new SqlConnection(DbHelperSQL.strConn)) { using (var cmd = new SqlCommand("iqc_detect01_submit", conn)) { try { conn.Open(); cmd.CommandType = CommandType.StoredProcedure; SqlParameter[] parameters = { new("@outMsg", SqlDbType.NVarChar, 300), new("@outSum", SqlDbType.Int), new("@inEdtUserGuid", _userGuid), new("@inOrderGuid", _guid), new("@inFieldValue", 1), new("@in1", ""), new("@in2", "") }; parameters[0].Direction = ParameterDirection.Output; parameters[1].Direction = ParameterDirection.Output; foreach (var parameter in parameters) cmd.Parameters.Add(parameter); cmd.ExecuteNonQuery(); m.outMsg = parameters[0].Value.ToString(); m.outSum = int.Parse(parameters[1].Value.ToString()); } catch (Exception ex) { m.outMsg = ex.Message; LogHelper.Debug(this.ToString(), "chk_iqc_detect01_submit error:" + ex.Message); return ReturnDto.QuickReturn(m, ReturnCode.Default, ex.Message); } finally { conn.Close(); } } } return ReturnDto.QuickReturn(m, ReturnCode.Success, "操作成功!"); } /// /// 质量,审核,反审核,驳回 /// /// /// [RequestMethod(RequestMethods.POST)] public ReturnDto EditModelSubmitZhiLiang([FromBody] dynamic mode) { string _guid = mode.guid; string _inFieldValue = mode.inFieldValue; dynamic m = new ExpandoObject(); m.outSum = -1; m.outMsg = ""; using (var conn = new SqlConnection(DbHelperSQL.strConn)) { using (var cmd = new SqlCommand("iqc_detect01_zhiLiang", conn)) { try { conn.Open(); cmd.CommandType = CommandType.StoredProcedure; SqlParameter[] parameters = { new("@outMsg", SqlDbType.NVarChar, 300), new("@outSum", SqlDbType.Int), new("@inEdtUserGuid", _userGuid), new("@inOrderGuid", _guid), new("@inFieldValue",_inFieldValue), new("@in1", ""), new("@in2", "") }; parameters[0].Direction = ParameterDirection.Output; parameters[1].Direction = ParameterDirection.Output; foreach (var parameter in parameters) cmd.Parameters.Add(parameter); cmd.ExecuteNonQuery(); m.outMsg = parameters[0].Value.ToString(); m.outSum = int.Parse(parameters[1].Value.ToString()); } catch (Exception ex) { m.outMsg = ex.Message; LogHelper.Debug(this.ToString(), "iqc_detect01_zhiliang error:" + ex.Message); return ReturnDto.QuickReturn(m, ReturnCode.Default, ex.Message); } finally { conn.Close(); } } } return ReturnDto.QuickReturn(m, ReturnCode.Success, "操作成功!"); } #endregion #region 样例管理 /// /// 读取 /// /// /// [RequestMethod(RequestMethods.POST)] public ReturnDto> GetYangLi([FromBody] dynamic model) { string guid = model.dt01Guid.ToString(); List lst = new List(); SqlParameter[] parameters = { new("@dt01Guid", guid), }; var dset = new DataSet(); try { dset = DbHelperSQL.RunProcedure("[iqc_detect01_13Lst]", parameters, "0"); if (dset != null && dset.Tables.Count > 0 && dset.Tables[0].Rows.Count > 0) { DataTable _tb = dset.Tables[1]; int maxYl = int.Parse(dset.Tables[0].Rows[0][0].ToString()); //在检验项目表上,根据样本数自动延申样本1,样本2,样本3…… for (int i = 1; i <= maxYl; i++) { _tb.Columns.Add("样本" + i.ToString(), typeof(decimal)); _tb.Columns.Add("样本" + i.ToString() + "jg", typeof(string)); }; DataTable _tb2 = dset.Tables[2]; //循环样本结果表的每一行 foreach (DataRow row in _tb.Rows) { //然后循环检验项目本的第一列 foreach (DataColumn col in _tb.Columns) { if (col.ColumnName.ToString().StartsWith("样本")) { string _idx = col.ColumnName.ToString().Replace("样本", ""); //排除样本数这一列 if (!string.IsNullOrEmpty(_idx) && _idx != "数") { DataRow[] _row = _tb2.Select(" parent_guid='" + row["guid"].ToString() + "' and fcheck_item='" + col.ColumnName.ToString().Trim() + "'"); if (_row.Length > 0) { row[col.ColumnName] = _row[0]["fcheck_resu"]; row[col.ColumnName + "jg"] = _row[0]["fstand"]; } } } } } lst = _tb.TableToDynamicList(); } } catch (Exception ex) { LogHelper.Debug(ToString(), ex.Message); } return ReturnDto>.QuickReturn(lst, ReturnCode.Success, "读取成功!"); } /// /// 增加或编辑实体 /// /// /// [RequestMethod(RequestMethods.POST)] public ReturnDto EditYangLi([FromBody] dynamic model) { Guid? guid = model.dt05Guid; //dt05Guid主键 string fSeq = model.fSeq; string fVal = model.fVal; dynamic mObj = new ExpandoObject(); mObj.outMsg = ""; mObj.outSum = -1; mObj.outGuid = ""; mObj.outNo = ""; using (var conn = new SqlConnection(DbHelperSQL.strConn)) { using (var cmd = new SqlCommand("[iqc_detect01_13edt]", conn)) { try { conn.Open(); cmd.CommandType = CommandType.StoredProcedure; SqlParameter[] parameters = { new("@outMsg", SqlDbType.NVarChar, 300), new("@outSum", SqlDbType.Int), new("@outGuid", SqlDbType.UniqueIdentifier), new("@outNo", SqlDbType.NVarChar, 300), new("@outFstand",SqlDbType.NVarChar, 10), new("@dt05Guid", CheckGuid(guid) ? guid : DBNull.Value), new("@fVal", fVal), new("@fSeq", fSeq), new("@inEdtUserGuid", _userGuid), }; parameters[0].Direction = ParameterDirection.Output; parameters[1].Direction = ParameterDirection.Output; parameters[2].Direction = ParameterDirection.Output; parameters[3].Direction = ParameterDirection.Output; parameters[4].Direction = ParameterDirection.Output; foreach (var parameter in parameters) cmd.Parameters.Add(parameter); cmd.ExecuteNonQuery(); mObj.outMsg = parameters[0].Value.ToString(); mObj.outSum = int.Parse(parameters[1].Value.ToString()); mObj.outGuid = parameters[2].Value.ToString(); mObj.outNo = parameters[3].Value.ToString(); mObj.outFstand = parameters[4].Value.ToString(); } catch (Exception ex) { LogHelper.Debug(ToString(), "iqc_detect01_13edt error:" + ex.Message); mObj.outMsg = ex.Message; mObj.outSum = -1; } finally { conn.Close(); } } } //if (mObj.outSum <= 0) // return ReturnDto.QuickReturn(mObj, ReturnCode.Exception, mObj.outMsg); return ReturnDto.QuickReturn(mObj, ReturnCode.Success, mObj.outMsg); } #endregion }