using Mapster; using SqlSugar; using SqlSugar.IOC; using System.Collections; using System.Linq.Expressions; using System.Reflection; using WMS.BZModels; using WMS.BZServices; using WMS.Info; namespace WMS.BZSqlSugar { public class Repository : SimpleClient where T : BaseEntityModel, new() { public Repository(ISqlSugarClient context = null) { //通过特性拿到ConfigId var configId = typeof(T).GetCustomAttribute()?.configId; if (configId != null) { Context = DbScoped.SugarScope.GetConnectionScope(configId);//根据类传入的ConfigId自动选择 } else { Context = context ?? DbScoped.SugarScope.GetConnectionScope("hj");//没有默认db0 } } //public Repository() //{ // //固定数据库用法 // Context = SqlSugarHelper.Db.GetConnectionScopeWithAttr(); //} public T InsertReturnEntity(T t) { //t = CheckId.InitId(t); return Context.Insertable(t).ExecuteReturnEntity(); } /// /// 该方法默认不更新AddWho,AddTime /// /// /// public bool UpdateEntity(T entity) { return Context.Updateable(entity).IgnoreColumns(new string[] { "AddWho", "AddTime" }).ExecuteCommand() > 0; } public bool UpdateModelColumns(Expression> Columns, Expression> WhereExpression) { return Update(Columns, WhereExpression); } public T GetModelByExpression(Expression> WhereExpression) { return GetSingle(WhereExpression); } //public ISugarQueryable Queryable() //{ // return Context.Queryable(); //} #region query public bool Any(Expression> expression) { return Context.Queryable().Where(expression).Any(); } public ISugarQueryable Queryable() { return Context.Queryable(); } public List SqlQueryToList(string sql, object obj = null) { return Context.Ado.SqlQuery(sql, obj); } /// /// 根据主值查询单条数据 /// /// 主键值 /// 泛型实体 public T GetId(object pkValue) { return Context.Queryable().InSingle(pkValue); } /// /// 根据条件查询分页数据 /// /// /// /// public PagedInfo GetPages(Expression> where, PagerInfo parm) { var source = Context.Queryable().Where(where); return source.ToPage(parm); } /// /// 分页获取数据 /// /// 条件表达式 /// /// /// /// public PagedInfo GetPages(Expression> where, PagerInfo parm, Expression> order, OrderByType orderEnum = OrderByType.Asc) { var source = Context .Queryable() .Where(where) .OrderByIF(orderEnum == OrderByType.Asc, order, OrderByType.Asc) .OrderByIF(orderEnum == OrderByType.Desc, order, OrderByType.Desc); return source.ToPage(parm); } public PagedInfo GetPages(Expression> where, PagerInfo parm, Expression> order, string orderByType) { return GetPages(where, parm, order, orderByType == "desc" ? OrderByType.Desc : OrderByType.Asc); } /// /// 查询所有数据(无分页,请慎用) /// /// public List GetAll(bool useCache = false, int cacheSecond = 3600) { return Context.Queryable().WithCacheIF(useCache, cacheSecond).ToList(); } #endregion query #region add /// /// 插入实体 /// /// /// public int Add(T t, bool ignoreNull = true) { return Context.Insertable(t).IgnoreColumns(ignoreNullColumn: ignoreNull).ExecuteCommand(); } public int Insert(List t) { return Context.Insertable(t).ExecuteCommand(); } public int Insert(T parm, Expression> iClumns = null, bool ignoreNull = true) { return Context.Insertable(parm).InsertColumns(iClumns).IgnoreColumns(ignoreNullColumn: ignoreNull).ExecuteCommand(); } public IInsertable Insertable(T t) { return Context.Insertable(t); } #endregion add #region delete public IDeleteable Deleteable() { return Context.Deleteable(); } /// /// 批量删除 /// /// /// public int Delete(object[] obj) { return Context.Deleteable().In(obj).ExecuteCommand(); } public int Delete(object id) { return Context.Deleteable(id).ExecuteCommand(); } public int DeleteTable() { return Context.Deleteable().ExecuteCommand(); } public bool Truncate() { return Context.DbMaintenance.TruncateTable(); } #endregion delete public DbResult LoginUseTran(Action action) { try { var result = Context.Ado.UseTran(() => action(), error => { var err = error as BZSysExCore; Context.Ado.RollbackTran(); throw new BZSysExCore(err!=null ?err.SysExType:0, error.Message); }); return result; } catch (Exception ex) { Context.Ado.RollbackTran(); Console.WriteLine(ex.Message); throw; } } public DbResult UseTranAction(Action action) { var result = Context.Ado.UseTran(() => action(), error => { var err = error as BZSysExCore; Context.Ado.RollbackTran(); throw new BZSysExCore(err != null ? err.SysExType : 0, error.Message); }); return result; } public DbResult UseTran(Action action) { try { var result = Context.Ado.UseTran(() => action()); return result; } catch (Exception ex) { Context.Ado.RollbackTran(); Console.WriteLine(ex.Message); throw; } } public IStorageable Storageable(T t) { return Context.Storageable(t); } public IStorageable Storageable(List t) { return Context.Storageable(t); } /// /// /// /// /// 增删改查方法 /// public DbResult UseTran(SqlSugarClient client, Action action) { try { var result = client.AsTenant().UseTran(() => action()); return result; } catch (Exception ex) { client.AsTenant().RollbackTran(); Console.WriteLine(ex.Message); throw; } } /// /// 使用事务 /// /// /// public bool UseTran2(Action action) { var result = Context.Ado.UseTran(() => action()); return result.IsSuccess; } } /// /// 分页查询扩展 /// public static class QueryableExtension { /// /// 读取列表 /// /// /// 查询表单式 /// 分页参数 /// public static PagedInfo ToPage(this ISugarQueryable source, Pagination parm) { var page = new PagedInfo(); var total = 0; page.PageSize = parm.rows; page.PageIndex = parm.page; parm.sidx = parm.sidx.Replace("DESC", "").Replace("ASC", ""); page.Result = source.OrderByIF(!parm.sidx.IsEmpty(), $"{parm.sidx.ToSqlFilter()} {(!string.IsNullOrWhiteSpace(parm.sord) && parm.sord.ToLower().Contains("desc") ? "desc" : "asc")}") .ToPageList(parm.page, parm.rows, ref total); page.TotalNum = total; return page; } /// /// 转指定实体类Dto /// /// /// /// /// /// public static PagedInfo ToPage(this ISugarQueryable source, Pagination parm) { var page = new PagedInfo(); var total = 0; page.PageSize = parm.rows; page.PageIndex = parm.page; parm.sidx = parm.sidx.Replace("DESC", "").Replace("ASC", ""); var result = source .OrderByIF(!parm.sidx.IsEmpty(), $"{parm.sidx.ToSqlFilter()} {(!string.IsNullOrWhiteSpace(parm.sord) && parm.sord.ToLower().Contains("desc") ? "desc" : "asc")}") .ToPageList(parm.page, parm.rows, ref total); page.TotalNum = total; page.Result = result.Adapt>(); return page; } /// /// 读取列表 /// /// /// 查询表单式 /// 分页参数 /// public static PagedInfo ToPage(this ISugarQueryable source, PagerInfo parm) { var page = new PagedInfo(); var total = 0; page.PageSize = parm.PageSize; page.PageIndex = parm.PageNum; parm.Sort = parm.Sort.Replace("DESC", "").Replace("ASC", ""); page.Result = source.OrderByIF(parm.Sort.IsNotEmpty(), $"{parm.Sort.ToSqlFilter()} {(!string.IsNullOrWhiteSpace(parm.SortType) && parm.SortType.ToLower().Contains("desc") ? "desc" : "asc")}") .ToPageList(parm.PageNum, parm.PageSize, ref total); page.TotalNum = total; return page; } /// /// 转指定实体类Dto /// /// /// /// /// /// public static PagedInfo ToPage(this ISugarQueryable source, PagerInfo parm) { var page = new PagedInfo(); var total = 0; page.PageSize = parm.PageSize; page.PageIndex = parm.PageNum; parm.Sort = parm.Sort.Replace("DESC", "").Replace("ASC", ""); var result = source .OrderByIF(parm.Sort.IsNotEmpty(), $"{parm.Sort.ToSqlFilter()} {(!string.IsNullOrWhiteSpace(parm.SortType) && parm.SortType.ToLower().Contains("desc") ? "desc" : "asc")}") .ToPageList(parm.PageNum, parm.PageSize, ref total); page.TotalNum = total; page.Result = result.Adapt>(); return page; } } public static partial class Extensions { public static bool IsEmpty(this object value) { if (value != null && !string.IsNullOrEmpty(value.ParseToString())) { return false; } else { return true; } } public static bool IsNotEmpty(this object value) { return !IsEmpty(value); } public static bool IsNullOrZero(this object value) { if (value == null || value.ParseToString().Trim() == "0") { return true; } else { return false; } } //public static bool IsAjaxRequest(this HttpRequest request) //{ // if (request == null) // throw new ArgumentNullException("request"); // if (request.Headers != null) // return request.Headers["X-Requested-With"] == "XMLHttpRequest"; // return false; //} } public static partial class Extensions { #region 转换为long /// /// 将object转换为long,若转换失败,则返回0。不抛出异常。 /// /// /// public static long ParseToLong(this object obj) { try { return long.Parse(obj.ToString()); } catch { return 0L; } } /// /// 将object转换为long,若转换失败,则返回指定值。不抛出异常。 /// /// /// /// public static long ParseToLong(this string str, long defaultValue) { try { return long.Parse(str); } catch { return defaultValue; } } #endregion #region 转换为int /// /// 将object转换为int,若转换失败,则返回0。不抛出异常。 /// /// /// public static int ParseToInt(this object str) { try { return Convert.ToInt32(str); } catch { return 0; } } /// /// 将object转换为int,若转换失败,则返回指定值。不抛出异常。 /// null返回默认值 /// /// /// /// public static int ParseToInt(this object str, int defaultValue) { if (str == null) { return defaultValue; } try { return Convert.ToInt32(str); } catch { return defaultValue; } } #endregion #region 转换为short /// /// 将object转换为short,若转换失败,则返回0。不抛出异常。 /// /// /// public static short ParseToShort(this object obj) { try { return short.Parse(obj.ToString()); } catch { return 0; } } /// /// 将object转换为short,若转换失败,则返回指定值。不抛出异常。 /// /// /// public static short ParseToShort(this object str, short defaultValue) { try { return short.Parse(str.ToString()); } catch { return defaultValue; } } #endregion #region 转换为demical /// /// 将object转换为demical,若转换失败,则返回指定值。不抛出异常。 /// /// /// public static decimal ParseToDecimal(this object str, decimal defaultValue) { try { return decimal.Parse(str.ToString()); } catch { return defaultValue; } } /// /// 将object转换为demical,若转换失败,则返回0。不抛出异常。 /// /// /// public static decimal ParseToDecimal(this object str) { try { return decimal.Parse(str.ToString()); } catch { return 0; } } #endregion #region 转化为bool /// /// 将object转换为bool,若转换失败,则返回false。不抛出异常。 /// /// /// public static bool ParseToBool(this object str) { try { return bool.Parse(str.ToString()); } catch { return false; } } /// /// 将object转换为bool,若转换失败,则返回指定值。不抛出异常。 /// /// /// public static bool ParseToBool(this object str, bool result) { try { return bool.Parse(str.ToString()); } catch { return result; } } #endregion #region 转换为float /// /// 将object转换为float,若转换失败,则返回0。不抛出异常。 /// /// /// public static float ParseToFloat(this object str) { try { return float.Parse(str.ToString()); } catch { return 0; } } /// /// 将object转换为float,若转换失败,则返回指定值。不抛出异常。 /// /// /// public static float ParseToFloat(this object str, float result) { try { return float.Parse(str.ToString()); } catch { return result; } } #endregion #region 转换为Guid /// /// 将string转换为Guid,若转换失败,则返回Guid.Empty。不抛出异常。 /// /// /// public static Guid ParseToGuid(this string str) { try { return new Guid(str); } catch { return Guid.Empty; } } #endregion #region 转换为DateTime /// /// 将string转换为DateTime,若转换失败,则返回日期最小值。不抛出异常。 /// /// /// public static DateTime ParseToDateTime(this string str) { try { if (string.IsNullOrWhiteSpace(str)) { return DateTime.MinValue; } if (str.Contains("-") || str.Contains("/")) { return DateTime.Parse(str); } else { int length = str.Length; switch (length) { case 4: return DateTime.ParseExact(str, "yyyy", System.Globalization.CultureInfo.CurrentCulture); case 6: return DateTime.ParseExact(str, "yyyyMM", System.Globalization.CultureInfo.CurrentCulture); case 8: return DateTime.ParseExact(str, "yyyyMMdd", System.Globalization.CultureInfo.CurrentCulture); case 10: return DateTime.ParseExact(str, "yyyyMMddHH", System.Globalization.CultureInfo.CurrentCulture); case 12: return DateTime.ParseExact(str, "yyyyMMddHHmm", System.Globalization.CultureInfo.CurrentCulture); case 14: return DateTime.ParseExact(str, "yyyyMMddHHmmss", System.Globalization.CultureInfo.CurrentCulture); default: return DateTime.ParseExact(str, "yyyyMMddHHmmss", System.Globalization.CultureInfo.CurrentCulture); } } } catch { return DateTime.MinValue; } } /// /// 将string转换为DateTime,若转换失败,则返回默认值。 /// /// /// /// public static DateTime ParseToDateTime(this string str, DateTime? defaultValue) { try { if (string.IsNullOrWhiteSpace(str)) { return defaultValue.GetValueOrDefault(); } if (str.Contains("-") || str.Contains("/")) { return DateTime.Parse(str); } else { int length = str.Length; switch (length) { case 4: return DateTime.ParseExact(str, "yyyy", System.Globalization.CultureInfo.CurrentCulture); case 6: return DateTime.ParseExact(str, "yyyyMM", System.Globalization.CultureInfo.CurrentCulture); case 8: return DateTime.ParseExact(str, "yyyyMMdd", System.Globalization.CultureInfo.CurrentCulture); case 10: return DateTime.ParseExact(str, "yyyyMMddHH", System.Globalization.CultureInfo.CurrentCulture); case 12: return DateTime.ParseExact(str, "yyyyMMddHHmm", System.Globalization.CultureInfo.CurrentCulture); case 14: return DateTime.ParseExact(str, "yyyyMMddHHmmss", System.Globalization.CultureInfo.CurrentCulture); default: return DateTime.ParseExact(str, "yyyyMMddHHmmss", System.Globalization.CultureInfo.CurrentCulture); } } } catch { return defaultValue.GetValueOrDefault(); } } #endregion #region 转换为string /// /// 将object转换为string,若转换失败,则返回""。不抛出异常。 /// /// /// public static string ParseToString(this object obj) { try { if (obj == null) { return string.Empty; } else { return obj.ToString(); } } catch { return string.Empty; } } public static string ParseToStrings(this object obj) { try { var list = obj as IEnumerable; if (list != null) { return string.Join(",", list); } else { return obj.ToString(); } } catch { return string.Empty; } } #endregion #region 转换为double /// /// 将object转换为double,若转换失败,则返回0。不抛出异常。 /// /// /// public static double ParseToDouble(this object obj) { try { return double.Parse(obj.ToString()); } catch { return 0; } } /// /// 将object转换为double,若转换失败,则返回指定值。不抛出异常。 /// /// /// /// public static double ParseToDouble(this object str, double defaultValue) { try { return double.Parse(str.ToString()); } catch { return defaultValue; } } #endregion #region 强制转换类型 /// /// 强制转换类型 /// /// /// /// public static IEnumerable CastSuper(this IEnumerable source) { foreach (object item in source) { yield return (TResult)Convert.ChangeType(item, typeof(TResult)); } } #endregion } }