using System.Collections.Generic; using System.Data; using System.Dynamic; using System.Linq.Expressions; using AgileObjects.AgileMapper; using Microsoft.AspNetCore.Http; using MySqlX.XDevAPI.Common; using Newtonsoft.Json.Linq; using NPOI.Util; using SqlSugar; using Tiobon.Core.Common; using Tiobon.Core.Common.Caches; using Tiobon.Core.Common.DB.Dapper; using Tiobon.Core.Common.DB.Dapper.Extensions; using Tiobon.Core.Common.Enums; using Tiobon.Core.Common.Extensions; using Tiobon.Core.Common.Helper; using Tiobon.Core.Common.UserManager; using Tiobon.Core.DataAccess; using Tiobon.Core.IRepository.Base; using Tiobon.Core.IServices.BASE; using Tiobon.Core.Model; using Tiobon.Core.Model.Models; namespace Tiobon.Core.Services.BASE; /// /// 增删改查基础服务 /// /// /// /// /// public class BaseServices : IBaseServices where TEntity : class, new() { public ICaching _caching; public BaseServices(IBaseRepository BaseDal = null, ICaching caching = null) { this.BaseDal = BaseDal; _caching = caching; } //public IBaseRepository baseDal = new BaseRepository(); public IBaseRepository BaseDal { get; set; } //通过在子类的构造函数中注入,这里是基类,不用构造函数 public ISqlSugarClient Db => BaseDal.Db; /// /// 根据ID查询实体数据是否存在 /// /// /// public async Task AnyAsync(object objId) { var data = await BaseDal.AnyAsync(objId); return data; } public async Task AnyAsync(Expression> whereExpression) { var data = await BaseDal.AnyAsync(whereExpression); return data; } public virtual async Task QueryById(object objId) { var data = new TEntity(); var dto = Mapper.Map(data).ToANew(); Type entityType = typeof(TEntity); string sql = @$"DECLARE @langId INT = 1,@ID BIGINT = '{objId}'; SELECT *, isnull ((SELECT CASE WHEN @langId = 1 THEN UserName ELSE UserEname END FROM Ghrs_User kk WHERE kk.UserId = a.CreateBy), '') + ' ' + [dbo].[FLangKeyToValue] ('GHR_Common_000078', @langId, '于 ') + ' ' + CONVERT (NVARCHAR (16), CreateTime, 121) + ' ' + [dbo].[FLangKeyToValue] ('GHR_Common_000079', @langId, ' 创建') CreateDataInfo, isnull ((SELECT CASE WHEN @langId = 1 THEN UserName ELSE UserEname END FROM Ghrs_User kk WHERE kk.UserId = a.UpdateBy), '') + ' ' + [dbo].[FLangKeyToValue] ('GHR_Common_000078', @langId, '于') + ' ' + CONVERT (NVARCHAR (16), UpdateTime, 121) + ' ' + [dbo].[FLangKeyToValue] ('GHR_Common_000080', @langId, ' 最后修改') UpdateDataInfo FROM {entityType.GetEntityTableName()} a WHERE a.Id = @ID"; dto = await Db.Ado.SqlQuerySingleAsync(sql); return dto; } /// /// 根据ID查询一条数据 /// /// id(必须指定主键特性 [SugarColumn(IsPrimaryKey=true)]),如果是联合主键,请使用Where条件 /// 是否使用缓存 /// 数据实体 public async Task QueryById(object objId, bool blnUseCache = false) { var data = await BaseDal.QueryById(objId, blnUseCache); return Mapper.Map(data).ToANew(); } /// /// 根据ID查询数据 /// /// id列表(必须指定主键特性 [SugarColumn(IsPrimaryKey=true)]),如果是联合主键,请使用Where条件 /// 数据实体列表 public async Task> QueryByIDs(object[] lstIds) { var data = await BaseDal.QueryByIDs(lstIds); return Mapper.Map(data).ToANew>(); } public virtual async Task QueryForm(QueryForm body) { var result = new ServiceFormResult(); string sql = string.Empty; var dt = new DataTable(); if (body.id != null) { Type entityType = typeof(TEntity); sql = @$"DECLARE @langId INT = '{body.langId}',@ID BIGINT = '{body.id}'; SELECT *, isnull ((SELECT CASE WHEN @langId = 1 THEN UserName ELSE UserEname END FROM Ghrs_User kk WHERE kk.UserId = a.CreateBy), '') + ' ' + [dbo].[FLangKeyToValue] ('GHR_Common_000078', @langId, '于 ') + ' ' + CONVERT (NVARCHAR (16), CreateTime, 121) + ' ' + [dbo].[FLangKeyToValue] ('GHR_Common_000079', @langId, ' 创建') CreateDataInfo, isnull ((SELECT CASE WHEN @langId = 1 THEN UserName ELSE UserEname END FROM Ghrs_User kk WHERE kk.UserId = a.UpdateBy), '') + ' ' + [dbo].[FLangKeyToValue] ('GHR_Common_000078', @langId, '于') + ' ' + CONVERT (NVARCHAR (16), UpdateTime, 121) + ' ' + [dbo].[FLangKeyToValue] ('GHR_Common_000080', @langId, ' 最后修改') UpdateDataInfo FROM {entityType.GetEntityTableName()} a WHERE a.Id = @ID"; result.result.DT_TableDataT1 = await Db.Ado.SqlQueryAsync(sql); } else { var list = new List { new TEntity() }; result.result.DT_TableDataT1 = Mapper.Map(list).ToANew>(); } #region JM_PageFormActionsT1 dynamic JM_PageFormActionsT1 = new ExpandoObject(); var toolbars = await _caching.GetAsync>(body.menuName + "FormToolbar"); if (toolbars == null || (toolbars != null && !toolbars.Any())) { sql = @$"SELECT field fnKey, [dbo].[FLangKeyToValue] (mkey, {body.langId}, label) fnTitle, icon FROM Ghrs_PageSettingEdit WHERE IsEnable = 1 AND pageNo = '{body.menuName}' AND elementType = 'FnKey'"; toolbars = await Db.Ado.SqlQueryAsync(sql); if (toolbars.Any()) await _caching.SetAsync(body.menuName + "FormToolbar", toolbars); } JM_PageFormActionsT1.Toolbar = toolbars; #endregion #region JM_TableColumnT1 dynamic JM_TableColumnT1 = new ExpandoObject(); var tableColumn = new JArray(); sql = @$"SELECT field, [dbo].[FLangKeyToValue] (mkey, {body.langId}, label) label, required, editable, rowNum, colNum, elementType, dbo.FS_GetdataSourceBySet (dataSource, APIDataSourceType, Ghrs_PageSettingEdit.APIDataSourceID) dataSource, defaultHidden, isPrimaryKey, isSingleColumn,multipleSelect FROM Ghrs_PageSettingEdit WHERE IsEnable = 1 AND pageNo = '{body.menuName}' AND elementType NOT IN ('FnKey', 'PageGroup');"; dt = await Db.Ado.GetDataTableAsync(sql); for (int i = 0; i < dt.Rows.Count; i++) { JObject item = [ new JProperty("field", dt.Rows[i]["field"].ToString()), new JProperty("label", dt.Rows[i]["label"].ToString()), new JProperty("required",!string.IsNullOrWhiteSpace(dt.Rows[i]["required"].ToString())? Convert.ToBoolean(dt.Rows[i]["required"]):null), new JProperty("editable",!string.IsNullOrWhiteSpace(dt.Rows[i]["editable"].ToString())? Convert.ToBoolean(dt.Rows[i]["editable"]):null), new JProperty("rowNum",!string.IsNullOrWhiteSpace(dt.Rows[i]["rowNum"].ToString())? Convert.ToInt32(dt.Rows[i]["rowNum"]):null), new JProperty("colNum",!string.IsNullOrWhiteSpace(dt.Rows[i]["colNum"].ToString())? Convert.ToInt32(dt.Rows[i]["colNum"]):null), new JProperty("elementType", dt.Rows[i]["elementType"].ToString()), new JProperty("dataSource", dt.Rows[i]["dataSource"].ToString()), new JProperty("defaultHidden", dt.Rows[i]["defaultHidden"].ToString()), new JProperty("isPrimaryKey", !string.IsNullOrWhiteSpace(dt.Rows[i]["isPrimaryKey"].ToString())? Convert.ToBoolean(dt.Rows[i]["isPrimaryKey"]):null), new JProperty("isSingleColumn",!string.IsNullOrWhiteSpace(dt.Rows[i]["isSingleColumn"].ToString())? Convert.ToInt32(dt.Rows[i]["isSingleColumn"]):null), new JProperty("multipleSelect",!string.IsNullOrWhiteSpace(dt.Rows[i]["multipleSelect"].ToString())? Convert.ToBoolean(dt.Rows[i]["multipleSelect"]):null), ]; tableColumn.Add(item); } JM_TableColumnT1.TableColumn = tableColumn; #endregion #region JM_PageFormT1 dynamic JM_PageFormT1 = new ExpandoObject(); var pageForm = new JArray(); JObject pageFormItem = [ new JProperty("disabled", false), new JProperty("labelAlign", "right"), new JProperty("labelCol", "{span: 6}"), new JProperty("labelWidth",120), new JProperty("layout", "horizontal") ]; sql = $@"SELECT [dbo].[FLangKeyToValue] (MKey, {body.langId}, MenuName) pageTitle, IUDProcedure apiName FROM Ghrs_Menu WHERE MenuNo = '{body.menuName}' AND IsEnable = 1"; dt = await Db.Ado.GetDataTableAsync(sql); if (dt.Rows.Count > 0) { pageFormItem.Add(new JProperty("pageTitle", dt.Rows[0]["pageTitle"].ToString())); pageFormItem.Add(new JProperty("apiName", dt.Rows[0]["apiName"].ToString())); } pageForm.Add(pageFormItem); JM_PageFormT1.PageForm = pageForm; #endregion #region DT_PageMutiMsg var DT_PageMutiMsg = await _caching.GetAsync>("DT_PageMutiMsg"); if (DT_PageMutiMsg == null || (DT_PageMutiMsg != null && !DT_PageMutiMsg.Any())) { sql = $@"SELECT Langkey field, CASE {body.langId} WHEN 1 THEN isnull (Value01, LangValue) WHEN 2 THEN isnull (Value02, LangValue) WHEN 3 THEN isnull (Value03, LangValue) WHEN 4 THEN isnull (Value04, LangValue) WHEN 5 THEN isnull (Value05, LangValue) WHEN 6 THEN isnull (Value06, LangValue) WHEN 7 THEN isnull (Value07, LangValue) WHEN 8 THEN isnull (Value08, LangValue) WHEN 9 THEN isnull (Value09, LangValue) WHEN 10 THEN isnull (Value10, LangValue) END label FROM Ghrs_LangKey WHERE (LangKey LIKE 'GHR_Page%' OR LangKey LIKE 'GHR_Common%') AND IsEnable = 1"; DT_PageMutiMsg = Db.Ado.SqlQuery(sql); if (DT_PageMutiMsg.Any()) await _caching.SetAsync("DT_PageMutiMsg", DT_PageMutiMsg); } #endregion result.result.JM_PageFormActionsT1 = JM_PageFormActionsT1; result.result.JM_TableColumnT1 = JM_TableColumnT1; result.result.JM_PageFormT1 = JM_PageFormT1; result.result.DT_PageMutiMsg = DT_PageMutiMsg; return result; } #region 新增 /// /// 写入实体数据 /// /// 实体类 /// public virtual async Task Add(TInsertDto entity) { HttpRequest request = UserContext.Context.Request; var api = request.Path.ObjToString().TrimEnd('/').ToLower(); var ip = GetUserIp(UserContext.Context); var entity1 = Mapper.Map(entity).ToANew(); BasePoco ent = entity1 as BasePoco; ent.CreateIP = ip; ent.CreateProg = api; #region 检查是否存在相同值 CheckOnly(entity1); #endregion return await BaseDal.Add(entity1); } /// /// 批量插入实体(速度快) /// /// 实体集合 /// 影响行数 public virtual async Task> Add(List listEntity) { var userId = UserContext.Current.User_Id; HttpRequest request = UserContext.Context.Request; var api = request.Path.ObjToString().TrimEnd('/').ToLower(); var ip = GetUserIp(UserContext.Context); var list = Mapper.Map(listEntity).ToANew>(); list.ForEach(entity => { BasePoco ent = entity as BasePoco; ent.CreateIP = ip; ent.CreateProg = api; #region 检查是否存在相同值 CheckOnly(entity); #endregion }); return await BaseDal.Add(list); } #endregion /// /// 更新实体数据 /// /// 实体类 /// public virtual async Task Update(long Id, TEditDto editModel) { HttpRequest request = UserContext.Context.Request; var api = request.Path.ObjToString().TrimEnd('/').ToLower(); var ip = GetUserIp(UserContext.Context); if (editModel == null || !await BaseDal.AnyAsync(Id)) return false; var entity = await BaseDal.QueryById(Id); ConvertTEditDto2TEntity(editModel, entity); BasePoco ent = entity as BasePoco; ent.UpdateIP = ip; ent.UpdateProg = api; CheckOnly(entity, Id); return await BaseDal.Update(entity); } public async Task Update(Dictionary editModels) { HttpRequest request = UserContext.Context.Request; var api = request.Path.ObjToString().TrimEnd('/').ToLower(); var ip = GetUserIp(UserContext.Context); List entities = new List(); foreach (var keyValuePairs in editModels) { if (keyValuePairs.Value == null || !BaseDal.Any(keyValuePairs.Key)) continue; var entity = await BaseDal.QueryById(keyValuePairs.Key); ConvertTEditDto2TEntity(keyValuePairs.Value, entity); BasePoco ent = entity as BasePoco; ent.UpdateIP = ip; ent.UpdateProg = api; CheckOnly(entity, keyValuePairs.Key); entities.Add(entity); } return await BaseDal.Update(entities); } /// /// 更新实体数据 /// /// 实体类 /// public async Task Update(List listEntity) { HttpRequest request = UserContext.Context.Request; var api = request.Path.ObjToString().TrimEnd('/').ToLower(); var ip = GetUserIp(UserContext.Context); listEntity.ForEach(entity => { BasePoco ent = entity as BasePoco; ent.UpdateIP = ip; ent.UpdateProg = api; }); return await BaseDal.Update(listEntity); } public async Task Update(TEntity entity, string where) { HttpRequest request = UserContext.Context.Request; var api = request.Path.ObjToString().TrimEnd('/').ToLower(); var ip = GetUserIp(UserContext.Context); BasePoco ent = entity as BasePoco; ent.UpdateIP = ip; ent.UpdateProg = api; return await BaseDal.Update(entity, where); } public async Task Update(object operateAnonymousObjects) { return await BaseDal.Update(operateAnonymousObjects); } public async Task Update(TEntity entity, List lstColumns = null, List lstIgnoreColumns = null, string where = "") { return await BaseDal.Update(entity, lstColumns, lstIgnoreColumns, where); } /// /// 根据实体删除一条数据 /// /// 实体类 /// public async Task Delete(TEntity entity) { return await BaseDal.Delete(entity); } /// /// 删除指定ID的数据 /// /// 主键ID /// public async Task DeleteById(object id) { return await BaseDal.DeleteById(id); } /// /// 删除指定ID的数据 /// /// 主键ID /// public async Task DeleteById1(object id) { var entity = await BaseDal.QueryById(id); BasePoco ent = entity as BasePoco; ent.IsEnable = 0; return await BaseDal.Update(entity); } /// /// 删除指定ID集合的数据(批量删除) /// /// 主键ID集合 /// public async Task DeleteByIds(object[] ids) { return await BaseDal.DeleteByIds(ids); } /// /// 删除指定ID集合的数据(批量删除) /// /// 主键ID集合 /// public async Task DeleteByIds1(long[] ids) { HttpRequest request = UserContext.Context.Request; var api = request.Path.ObjToString().TrimEnd('/').ToLower(); var ip = GetUserIp(UserContext.Context); List entities = new List(); foreach (var id in ids) { if (id == null || !BaseDal.Any(id)) continue; var entity = await BaseDal.QueryById(id); BasePoco ent = entity as BasePoco; ent.UpdateIP = ip; ent.UpdateProg = api; ent.IsEnable = 0; entities.Add(entity); } return await BaseDal.Update(entities); } /// /// 根据表达式,删除实体 /// /// 表达式 /// public async Task Delete(Expression> whereExpression) { return await BaseDal.Delete(whereExpression); } /// /// 查询所有数据 /// /// 数据列表 public async Task> Query() { return await BaseDal.Query(); } /// /// 查询数据列表 /// /// 条件 /// 数据列表 public async Task> Query(string where) { return await BaseDal.Query(where); } /// /// 查询数据列表 /// /// whereExpression /// 数据列表 public async Task> Query(Expression> whereExpression) { return await BaseDal.Query(whereExpression); } public async Task QuerySingleDto(Expression> whereExpression) { var entitys = await BaseDal.Query(whereExpression); var entity = entitys.FirstOrDefault(); if (entity == null) return default; else return Mapper.Map(entity).ToANew(); } /// /// 按照特定列查询数据列表 /// /// /// /// public async Task> Query(Expression> expression) { return await BaseDal.Query(expression); } /// /// 按照特定列查询数据列表带条件排序 /// /// /// 过滤条件 /// 查询实体条件 /// 排序条件 /// public async Task> Query(Expression> expression, Expression> whereExpression, string orderByFileds) { return await BaseDal.Query(expression, whereExpression, orderByFileds); } /// /// 查询一个列表 /// /// 条件表达式 /// 排序字段,如name asc,age desc /// 数据列表 public async Task> Query(Expression> whereExpression, Expression> orderByExpression, bool isAsc = true) { return await BaseDal.Query(whereExpression, orderByExpression, isAsc); } public async Task> Query(Expression> whereExpression, string orderByFileds) { return await BaseDal.Query(whereExpression, orderByFileds); } /// /// 查询一个列表 /// /// 条件 /// 排序字段,如name asc,age desc /// 数据列表 public async Task> Query(string where, string orderByFileds) { return await BaseDal.Query(where, orderByFileds); } /// /// 根据sql语句查询 /// /// 完整的sql语句 /// 参数 /// 泛型集合 public async Task> QuerySql(string sql, SugarParameter[] parameters = null) { return await BaseDal.QuerySql(sql, parameters); } /// /// 根据sql语句查询 /// /// 完整的sql语句 /// 参数 /// DataTable public async Task QueryTable(string sql, SugarParameter[] parameters = null) { return await BaseDal.QueryTable(sql, parameters); } /// /// 查询前N条数据 /// /// 条件表达式 /// 前N条 /// 排序字段,如name asc,age desc /// 数据列表 public async Task> Query(Expression> whereExpression, int top, string orderByFileds) { return await BaseDal.Query(whereExpression, top, orderByFileds); } /// /// 查询前N条数据 /// /// 条件 /// 前N条 /// 排序字段,如name asc,age desc /// 数据列表 public async Task> Query(string where, int top, string orderByFileds) { return await BaseDal.Query(where, top, orderByFileds); } /// /// 分页查询 /// /// 条件表达式 /// 页码(下标0) /// 页大小 /// 排序字段,如name asc,age desc /// 数据列表 public async Task> Query(Expression> whereExpression, int pageIndex, int pageSize, string orderByFileds) { return await BaseDal.Query(whereExpression, pageIndex, pageSize, orderByFileds); } /// /// 分页查询 /// /// 条件 /// 页码(下标0) /// 页大小 /// 排序字段,如name asc,age desc /// 数据列表 public async Task> Query(string where, int pageIndex, int pageSize, string orderByFileds) { return await BaseDal.Query(where, pageIndex, pageSize, orderByFileds); } public async Task> QueryPage(Expression> whereExpression, int pageIndex = 1, int pageSize = 20, string orderByFileds = null) { return await BaseDal.QueryPage(whereExpression, pageIndex, pageSize, orderByFileds); } public virtual async Task> QueryFilterPage(QueryBody body) { if (string.IsNullOrWhiteSpace(body.orderBy)) body.orderBy = "CreateTime DESC"; var data = await BaseDal.QueryFilterPage(body); return new ServicePageResult(body.pageNum, data.result.DT_TablePageInfoT1.TotalCount, body.pageSize, Mapper.Map(data.result.DT_TableDataT1).ToANew>()); } public async Task> Export(QueryBody body) { //sql = @$"SELECT field, // [dbo].[FLangKeyToValue] (mkey, {body.langId}, label) // label, // required, // editable, // rowNum, // colNum, // elementType, // dbo.FS_GetdataSourceBySet // (dataSource, APIDataSourceType, Ghrs_PageSettingEdit.APIDataSourceID) // dataSource, // defaultHidden, // isPrimaryKey, // isSingleColumn // FROM Ghrs_PageSettingEdit // WHERE IsEnable = 1 // AND pageNo = '{body.menuName}' // AND elementType NOT IN ('FnKey', 'PageGroup');"; //dt = await Db.Ado.GetDataTableAsync(sql); var data = await BaseDal.QueryFilterPage(body); var fileId = await ReportHelper.SendFile(data.result.DT_TableDataT1.AsQueryable(), $"测试测试", null, null, null, null); return ServiceResult.OprateSuccess("导出成功", fileId); } public async Task> QueryMuch(Expression> joinExpression, Expression> selectExpression, Expression> whereLambda = null) where T : class, new() { return await BaseDal.QueryMuch(joinExpression, selectExpression, whereLambda); } public async Task> QueryPage(PaginationModel pagination) { var express = DynamicLinqFactory.CreateLambda(pagination.Conditions); return await QueryPage(express, pagination.PageIndex, pagination.PageSize, pagination.OrderByFileds); } #region 分表 public async Task> AddSplit(TEntity entity) { return await BaseDal.AddSplit(entity); } public async Task UpdateSplit(TEntity entity, DateTime dateTime) { return await BaseDal.UpdateSplit(entity, dateTime); } /// /// 根据实体删除一条数据 /// /// 实体类 /// public async Task DeleteSplit(TEntity entity, DateTime dateTime) { return await BaseDal.DeleteSplit(entity, dateTime); } public async Task QueryByIdSplit(object objId) { return await BaseDal.QueryByIdSplit(objId); } public async Task> QueryPageSplit(Expression> whereExpression, DateTime beginTime, DateTime endTime, int pageIndex = 1, int pageSize = 20, string orderByFields = null) { return await BaseDal.QueryPageSplit(whereExpression, beginTime, endTime, pageIndex, pageSize, orderByFields); } #endregion public static string GetUserIp(HttpContext context) { string realIP = null; string forwarded = null; string remoteIpAddress = context.Connection.RemoteIpAddress.ToString(); if (context.Request.Headers.ContainsKey("X-Real-IP")) { realIP = context.Request.Headers["X-Real-IP"].ToString(); if (realIP != remoteIpAddress) { remoteIpAddress = realIP; } } if (context.Request.Headers.ContainsKey("X-Forwarded-For")) { forwarded = context.Request.Headers["X-Forwarded-For"].ToString(); if (forwarded != remoteIpAddress) { remoteIpAddress = forwarded; } } remoteIpAddress = remoteIpAddress.Replace("::ffff:", null); return remoteIpAddress; } #region 辅助方法 /// /// 转换TEditDto2TEntity /// /// /// /// protected void ConvertTEditDto2TEntity(TEditDto source, TEntity dest) { foreach (System.Reflection.PropertyInfo mItem in typeof(TEditDto).GetProperties()) { if (dest.HasField(mItem.Name)) dest.SetValueForField(mItem.Name, mItem.GetValue(source, null)); } //dest.SetValueForField(DbConsts.ColunmName_LastModificationTime, DateTimeHelper.Now()); //if (_currentUserId != default) //{ // //dest.SetValueForField(DbConsts.ColunmName_LastModifierId, _currentUserId); // dest.SetValueForField(DbConsts.ColunmName_LastModifier, _currentUserName); //} //if (_currentTenantId != null) //{ // dest.SetValueForField(DbConsts.ColunmName_TenantId, _currentTenantId); //} } /// /// 获取根据ID查询的条件 /// /// /// protected QueryFilter QueryFilterById(Guid id) { return new QueryFilter { PageIndex = 1, PageSize = 1, Sorting = string.Empty, Conditions = string.Empty }; } #region 检查表中是否已经存在相同代码的数据 public static void CheckOnly(TEntity entity, long? id = null) { Type entityType = typeof(TEntity); var tableName = entityType.GetEntityTableName(); var names = new List(); var values = new List(); var descriptions = new List(); entity.GetOnlyList(out names, out values, out descriptions); for (int i = 0; i < names.Count; i++) { CheckCodeExist(tableName, names[i], values[i], id != null ? ModifyType.Edit : ModifyType.Add, descriptions[i], id); } } /// /// 检查表中是否已经存在相同代码的数据 /// /// 表名 /// 字段名 /// 字段值 /// ModifyType.Add,ModifyType.Edit /// ModifyType.Edit时修改记录的ROW_ID值 /// 判断栏位的提示名称 public static void CheckCodeExist(string tableName, string fieldName, object fieldValue, ModifyType modifyType, string promptName, long? rowid = null) { try { CheckCodeExist(tableName, fieldName, fieldValue, modifyType, rowid, promptName, null); } catch (Exception) { throw; } } /// /// 检查表中是否已经存在相同代码的数据 /// /// 表名 /// 字段名 /// 字段值 /// 条件 /// ModifyType.Add,ModifyType.Edit /// ModifyType.Edit时修改记录的ROW_ID值 /// 判断栏位的提示名称 /// Where后的条件,如:IS_ALCON='Y' public static bool CheckCodeExist(string tableName, string fieldName, object fieldValue, ModifyType modifyType, long? rowid, string promptName, string whereCondition) { try { bool result = false; if (modifyType == ModifyType.Add) { string sql = string.Empty; sql = "SELECT COUNT(*) FROM " + tableName + " WHERE " + fieldName + "='" + fieldValue + "' AND IsEnable=1"; if (!string.IsNullOrEmpty(whereCondition)) sql += " AND " + whereCondition; int count = Convert.ToInt32(DbAccess.ExecuteScalar(sql)); if (count > 0) { result = true; throw new Exception(string.Format("{0}【{1}】已经存在!", promptName, fieldValue)); } else result = false; } else if (modifyType == ModifyType.Edit) { string sql = string.Empty; sql = "SELECT COUNT(*) FROM " + tableName + " WHERE " + fieldName + "='" + fieldValue + "' AND IsEnable=1 AND ID!='" + rowid.Value + "'"; if (!string.IsNullOrEmpty(whereCondition)) sql += " AND " + whereCondition; int count = Convert.ToInt32(DbAccess.ExecuteScalar(sql)); if (count > 0) { result = true; throw new Exception(string.Format("{0}【{1}】已经存在!", promptName, fieldValue)); } else result = false; } return result; } catch (Exception) { throw; } } #endregion #region 自动编号 /// /// 自动编号 /// /// 表名 /// 栏位名 /// 前缀 /// public async Task GenerateContinuousSequence(string tableCode, string columnCode, string prefixTemp) { try { string result = string.Empty; int length = 7; int tempLength = 6; int sequence; #region 查询 DbSelect dbSelect = new DbSelect(tableCode + " A", "A", null); dbSelect.IsInitDefaultValue = false; if (!string.IsNullOrEmpty(prefixTemp)) dbSelect.Select("MAX(SUBSTRING(A." + columnCode + "," + (prefixTemp.Length + 1).ToString() + "," + tempLength.ToString() + "))"); else dbSelect.Select("MAX(A." + columnCode + ")"); //} //dbSelect.Select("MAX(CONVERT(DECIMAL,SUBSTRING(A.ISSUE_NO," + (prefix.Length + dateString.Length + 1).ToString() + "," + tempLength.ToString() + ")))"); if (!string.IsNullOrEmpty(prefixTemp)) dbSelect.Where("SUBSTRING(A." + columnCode + ",1," + (prefixTemp.Length).ToString() + ")", " = ", prefixTemp); dbSelect.Where("LEN(A." + columnCode + ")", "=", length); string sql = dbSelect.GetSql(); //await Db.Ado.GetScalarAsync(sql) string maxSequence = Convert.ToString(await Db.Ado.GetScalarAsync(sql)); #endregion //tempLength = tempLength - dateString.Length; if (string.IsNullOrEmpty(maxSequence)) result = prefixTemp + Convert.ToString(1).PadLeft(tempLength, '0'); else { if (!string.IsNullOrEmpty(prefixTemp)) { if (int.TryParse(maxSequence, out sequence)) { sequence += 1; if (sequence.ToString().Length > tempLength) throw new Exception("自动生成字串长度已经超过设定长度!"); } else throw new Exception("表中的数据无法进行自动编号,请联系软件开发商!"); result = prefixTemp + sequence.ToString().PadLeft(tempLength, '0'); } else { if (int.TryParse(maxSequence, out sequence)) { sequence += 1; if (sequence.ToString().Length > length) throw new Exception("自动生成字串长度已经超过设定长度!"); } else throw new Exception("表中的数据无法进行自动编号,请联系软件开发商!"); result = sequence.ToString().PadLeft(length, '0'); } } return result; } catch (Exception) { throw; } } #endregion #region 获取通用参数设定 public async Task GetParaLabel(string key, string value) { string label = value; var list = await _caching.GetAsync>(key); if (list == null || (list != null && !list.Any())) { string sql = $"SELECT * FROM Ghrs_ParaDetail WHERE ParaMasterNo ='{key}' ORDER BY SortNo ASC"; list = DbAccess.QueryList(sql); if (list.Any()) await _caching.SetAsync(key, list); } if (list.Any(x => x.ParaDetailNo == value)) label = list.FirstOrDefault(x => x.ParaDetailNo == value)?.ParaDetailName; return label; } #endregion public string GetQueryString(string sqlSelect, int? currentPage = null, int? pageSize = null, string sortField = null, string sortDirection = null) { string queryString = string.Empty; if (string.IsNullOrEmpty(sortField)) queryString = "SELECT * FROM (SELECT *, ROW_NUMBER() OVER (ORDER BY ROW_ID) NUM FROM (SELECT * FROM (" + sqlSelect + " WHERE 1=1 "; else { if (!string.IsNullOrEmpty(sortDirection)) queryString = "SELECT * FROM (SELECT *, ROW_NUMBER() OVER (ORDER BY " + sortField + " " + sortDirection + ") NUM FROM (SELECT * FROM (" + sqlSelect + " "; else queryString = "SELECT * FROM (SELECT *, ROW_NUMBER() OVER (ORDER BY " + sortField + " DESC) NUM FROM (SELECT * FROM (" + sqlSelect + " "; } queryString += ") A ) B ) C"; if (currentPage != null && pageSize != null) queryString += " WHERE NUM <= " + currentPage * pageSize + " AND NUM >" + (currentPage - 1) * pageSize; return queryString; } //public int GetTotalCount(string sqlSelect) //{ // string sql = string.Empty; // try // { // int count = Convert.ToInt32(DBHelper.ExecuteScalar(sql)); // return count; // } // catch (Exception Ex) // { // throw; // } //} #endregion }