/// <summary> /// 查詢業務基實現 /// </summary> /// <typeparam name="T"></typeparam> public class QueryBaseBusiness<T> : IQueryBaseBusiness<T> where T : class { /// <summary> /// 是否跟蹤上下文 /// <para>可提高性能</para> /// </summary> public bool asNoTracking { get; set; } /// <summary> /// 數據上下文對象 /// </summary> public Payu_DatabaseContext context { get; set; } /// <summary> /// Initializes a new instance of the <see cref="Payu.Business.Base.QueryBaseBusiness{T}"/> class. /// </summary> public QueryBaseBusiness() { context = EFContextFactory.GetCurrentDbContext(); } /// <summary> /// 設置query 查詢對象 /// </summary> /// <param name="query">The query.</param> /// <returns></returns> public IQueryable<T> SetQueryable(IQueryable<T> query) { if (!this.asNoTracking) { query = query.AsNoTracking(); } return query; } /// <summary> /// 設置query 查詢對象 /// </summary> /// <param name="query">The query.</param> /// <returns></returns> public IQueryable<OutT> SetQueryable<OutT>(IQueryable<OutT> query) where OutT : class { if (!this.asNoTracking) { query = query.AsNoTracking(); } return query; } /// <summary> /// 根據表達式查詢返回總個數. /// </summary> /// <param name="where">The where.</param> /// <returns></returns> public IBusinessResponse<Int32> GetCount(Expression<Func<T, bool>> where) { var count = this.GetQueryable(where).Count(); return new BusinessResponse<Int32>(count); } /// <summary> /// 根據表達式查詢返回總個數 /// </summary> /// <param name="where"></param> /// <param name="selectExpression">統計的對象</param> /// <returns></returns> public IBusinessResponse<Int32> GetCount<TKey>(Expression<Func<T, bool>> where, Expression<Func<T, TKey>> selectExpression) { var query = this.GetQueryable(where); var count = query.Select(selectExpression).Count(); return new BusinessResponse<Int32>(count); } /// <summary> /// 根據 where 返回集合對象 /// </summary> /// <param name="where"></param> /// <returns></returns> public IBusinessResponse<ICollection<T>> GetByWhere(Expression<Func<T, bool>> where) { var result = this.GetQueryable(where).ToList(); return new BusinessResponse<ICollection<T>>(result); } /// <summary> /// 根據 where 條件返回 集合對象 /// </summary> /// <typeparam name="TOut">返回類型</typeparam> /// <param name="where">查詢條件.</param> /// <param name="selectExpression">查詢表達式</param> /// <returns></returns> public IBusinessResponse<ICollection<TOut>> GetByWhere<TOut>(Expression<Func<T, bool>> where, Expression<Func<T, TOut>> selectExpression) { var query_data = this.GetQueryable().Where(where).Select(selectExpression).ToList(); return new BusinessResponse<ICollection<TOut>>(query_data); } /// <summary> /// 根據 where 條件返回 集合對象 /// </summary> /// <typeparam name="TOut">返回的泛型類型</typeparam> /// <typeparam name="TKey">排序的類型</typeparam> /// <param name="where">查詢條件.</param> /// <param name="orderLambda">排序表達式</param> /// <param name="selectExpression">查詢表達式</param> /// <returns></returns> public IBusinessResponse<ICollection<TOut>> GetByWhere<TOut, TKey>(Expression<Func<T, bool>> where, Expression<Func<T, TKey>> orderLambda, Expression<Func<T, TOut>> selectExpression) { var query_data = this.GetQueryable().Where(where).OrderBy(orderLambda).Select(selectExpression).ToList(); return new BusinessResponse<ICollection<TOut>>(query_data); } /// <summary> /// 根據表達式返回單個元素 /// </summary> /// <param name="where"></param> /// <returns></returns> public IBusinessResponse<T> GetFirstByWhere(Expression<Func<T, bool>> where) { var entity = this.GetQueryable(where).FirstOrDefault(); if (entity == null) { return new BusinessResponse<T>(false, "數據不存在", "Not_Data"); } return new BusinessResponse<T>(entity); } /// <summary> /// 根據表達式返回單個元素 /// <para>帶有Select</para> /// </summary> /// <param name="where"></param> /// <param name="selectExpression">查詢對象</param> /// <returns></returns> public IBusinessResponse<TOut> GetFirstByWhere<TOut>(Expression<Func<T, bool>> where, Expression<Func<T, TOut>> selectExpression) { var query = this.GetQueryable(where); var entity = query.Select(selectExpression).FirstOrDefault(); return new BusinessResponse<TOut>(entity); } /// <summary> /// 得到惟一一個對象 /// </summary> /// <param name="where"></param> /// <returns></returns> public IBusinessResponse<T> GetSingleByWhere(Expression<Func<T, bool>> where) { var entity = context.Set<T>().Where(where).SingleOrDefault(); if (entity == null) { return new BusinessResponse<T>(false, "數據不存在", "Not_Data"); } return new BusinessResponse<T>(entity); } /// <summary> /// 得到惟一一個對象 /// </summary> /// <param name="where"></param> /// <param name="selectExpression"></param> /// <returns></returns> public IBusinessResponse<TOut> GetSingleByWhere<TOut>(Expression<Func<T, bool>> where, Expression<Func<T, TOut>> selectExpression) { var entity = this.GetQueryable(where).Select(selectExpression).SingleOrDefault(); return new BusinessResponse<TOut>(entity); } /// <summary> /// 根據表達式返回最後一個元素 /// </summary> /// <param name="where"></param> /// <returns></returns> public IBusinessResponse<T> GetLastByWhere(Expression<Func<T, bool>> where) { var query = context.Set<T>().Where(where).AsQueryable(); var entity = query.LastOrDefault(); if (entity == null) { return new BusinessResponse<T>(false, "數據不存在", "Not_Data"); } return new BusinessResponse<T>(entity); } /// <summary> /// 根據表達式返回最後一個元素 /// </summary> /// <typeparam name="TOut">The type of the out.</typeparam> /// <param name="where">The where.</param> /// <param name="selectExpression">The select expression.</param> /// <returns></returns> public IBusinessResponse<TOut> GetLastByWhere<TOut>(Expression<Func<T, bool>> where, Expression<Func<T, TOut>> selectExpression) { var query = this.GetQueryable(where); var entity = query.Select(selectExpression).LastOrDefault(); return new BusinessResponse<TOut>(entity); } /// <summary> /// /// </summary> /// <param name="where"></param> /// <returns></returns> public IBusinessResponse<bool> AnyByWhere(Expression<Func<T, bool>> where) { var isAny = this.GetQueryable().Any(where); if (isAny) { return new BusinessResponse<bool>(true, "已存在", "Exist_Data") { Data = true }; } return new BusinessResponse<bool>(false, "不存在", "Not_Data"); } /// <summary> /// 得到指定的查詢對象 /// </summary> /// <returns></returns> public IQueryable<TOut> GetQueryable_Out<TOut>(Expression<Func<TOut, bool>> where) where TOut : class { var query = this.context.Set<TOut>().Where(where); query = SetQueryable(query); return query; } /// <summary> /// 得到當前的查詢對象 /// </summary> /// <returns></returns> public IQueryable<OutT> GetQueryable_Out<OutT>() where OutT : class { var query = this.context.Set<OutT>().AsQueryable(); query = SetQueryable(query); return query; } /// <summary> /// 執行分頁 /// </summary> /// <param name="query">查詢對象</param> /// <param name="result">返回對象</param> /// <param name="paging">分頁對象</param> public IPagingBusinessResponse<ICollection<OutT>> ExecutePage_Out<OutT>(IQueryable<OutT> query, IPagingBusinessResponse<ICollection<OutT>> result, Paging paging) where OutT : class { result.Data = query.Skip((paging.PageIndex - 1) * paging.PageSize).Take(paging.PageSize).ToList(); paging.Total = query.FutureCount().Value; paging.PageSize = paging.PageSize; paging.PageIndex = paging.PageIndex; result.Paging = paging; return result; } /// <summary> /// 得到當前的查詢對象 /// </summary> /// <returns></returns> public virtual IQueryable<T> GetQueryable() { var query = this.context.Set<T>().AsQueryable(); query = SetQueryable(query); return query; } /// <summary> /// 得到當前的查詢對象 /// </summary> /// <returns></returns> public virtual IQueryable<T> GetQueryable(Expression<Func<T, bool>> where) { var query = this.context.Set<T>().Where(where); query = SetQueryable(query); return query; } /// <summary> /// 得到當前的查詢對象 /// </summary> /// <returns></returns> public IQueryable<dynamic> GetQueryable(Expression<Func<T, bool>> where, Expression<Func<T, dynamic>> selectExpression) { var query = this.context.Set<T>().Where(where); query = SetQueryable(query); return query.Select(selectExpression); } /// <summary> /// 得到當前的查詢對象 /// </summary> /// <returns></returns> public IQueryable<TOut> GetQueryable<TOut>(Expression<Func<T, bool>> where, Expression<Func<T, TOut>> selectExpression) { var query = this.context.Set<T>().Where(where); query = SetQueryable(query); return query.Select(selectExpression); } /// <summary> /// 執行分頁_動態操做 /// </summary> /// <param name="query">查詢對象</param> /// <param name="result">返回對象</param> /// <param name="paging">分頁對象</param> /// <param name="selectExpression"></param> public IPagingBusinessResponse<dynamic> ExecutePage_Dynamic(IQueryable<T> query, IPagingBusinessResponse<dynamic> result, Paging paging, Expression<Func<T, dynamic>> selectExpression) { result.Data = query.Select(selectExpression).Skip((paging.PageIndex - 1) * paging.PageSize).Take(paging.PageSize).ToList(); paging.Total = query.FutureCount().Value; paging.PageSize = paging.PageSize; paging.PageIndex = paging.PageIndex; result.Paging = paging; return result; } /// <summary> /// 執行分頁_動態操做 /// </summary> /// <param name="where">查詢條件</param> /// <param name="orderLambda">排序表達式</param> /// <param name="codeOrderType">排序方式</param> /// <param name="paging">分頁參數</param> /// <param name="selectExpression">動態類型</param> /// <returns></returns> public IPagingBusinessResponse<dynamic> ExecutePage_Dynamic<TKey>(Expression<Func<T, bool>> where, Expression<Func<T, TKey>> orderLambda, CodeOrderType codeOrderType, Paging paging, Expression<Func<T, dynamic>> selectExpression) { var query = this.GetQueryable(where); if (codeOrderType == CodeOrderType.Asc) { query = query.OrderBy(orderLambda); } else if (codeOrderType == CodeOrderType.Desc) { query = query.OrderByDescending(orderLambda); } var result = new PagingBusinessResponse<dynamic> { Data = query.Select(selectExpression).Skip((paging.PageIndex - 1) * paging.PageSize).Take(paging.PageSize).ToList() }; paging.Total = query.FutureCount().Value; paging.PageSize = paging.PageSize; paging.PageIndex = paging.PageIndex; result.Paging = paging; return result; } /// <summary> /// 執行分頁 /// <para>返回動態對象</para> /// </summary> /// <param name="query">查詢對象</param> /// <param name="paging">分頁對象</param> /// <param name="selectExpression">動態表達式</param> public IPagingBusinessResponse<dynamic> ExecutePage_Dynamic(IQueryable<T> query, Paging paging, Expression<Func<T, dynamic>> selectExpression) { var result = new PagingBusinessResponse<dynamic> { Data = query.Select(selectExpression).Skip((paging.PageIndex - 1) * paging.PageSize).Take(paging.PageSize).ToList() }; paging.Total = query.FutureCount().Value; paging.PageSize = paging.PageSize; paging.PageIndex = paging.PageIndex; result.Paging = paging; return result; } /// <summary> /// 執行分頁 /// </summary> /// <param name="query">查詢對象</param> /// <param name="result">返回對象</param> /// <param name="paging">分頁對象</param> public IPagingBusinessResponse<ICollection<T>> ExecutePage(IQueryable<T> query, IPagingBusinessResponse<ICollection<T>> result, Paging paging) { result.Data = query.Skip((paging.PageIndex - 1) * paging.PageSize).Take(paging.PageSize).ToList(); paging.Total = query.FutureCount().Value; paging.PageSize = paging.PageSize; paging.PageIndex = paging.PageIndex; result.Paging = paging; return result; } /// <summary> /// 執行分頁 /// </summary> /// <param name="query">查詢對象</param> /// <param name="paging">分頁對象</param> public IPagingBusinessResponse<ICollection<T>> ExecutePage(IQueryable<T> query, Paging paging) { var result = new PagingBusinessResponse<ICollection<T>> { Data = query.Skip((paging.PageIndex - 1) * paging.PageSize).Take(paging.PageSize).ToList() }; paging.Total = query.FutureCount().Value; paging.PageSize = paging.PageSize; paging.PageIndex = paging.PageIndex; result.Paging = paging; return result; } /// <summary> /// 執行分頁 /// <para>返回傳入的類型</para> /// </summary> /// <typeparam name="Tout">返回的類型</typeparam> /// <param name="query">當前的查詢對象</param> /// <param name="paging">分頁參數</param> /// <param name="selectExpression">查詢表達式</param> /// <returns></returns> public IPagingBusinessResponse<ICollection<Tout>> ExecutePage<Tout>(IQueryable<T> query, Paging paging, Expression<Func<T, Tout>> selectExpression) { var result = new PagingBusinessResponse<ICollection<Tout>> { Data = query.Select(selectExpression).Skip((paging.PageIndex - 1) * paging.PageSize).Take(paging.PageSize).ToList() }; // paging.Total = query.FutureCount().Value; paging.Total = query.Count(); paging.PageSize = paging.PageSize; paging.PageIndex = paging.PageIndex; result.Paging = paging; return result; } /// <summary> /// 得到題目下的全部題意理解 /// </summary> /// <param name="id">編號</param> /// <returns></returns> public IBusinessResponse<T> GetById(dynamic id) { var entity = context.Set<T>().Find(id); if (entity == null) { return new BusinessResponse<T>(false, "編號" + id + "不存在", "Not_Data"); } return new BusinessResponse<T>(entity); } /// <summary> /// Executes the select SQL. /// <para>執行查詢語句</para> /// <para>返回TIn 泛型單個對象</para> /// </summary> /// <typeparam name="TIn">返回映射泛型</typeparam> /// <param name="sql">The SQL.</param> /// <returns></returns> public TIn ExecSelectSql<TIn>(string sql) { return context.Database.SqlQuery<TIn>(sql).FirstOrDefault(); } /// <summary> /// Executes the select SQL. /// <para>執行查詢語句</para> /// <para>返回TIn 泛型單個對象</para> /// </summary> /// <typeparam name="TIn">返回映射泛型</typeparam> /// <param name="sql">The SQL.</param> /// <param name="parameters">The parameters.</param> /// <returns></returns> public TIn ExecSelectSql<TIn>(string sql, params object[] parameters) { return context.Database.SqlQuery<TIn>(sql, parameters).FirstOrDefault(); } /// <summary> /// Executes the select SQL to list. /// <para>執行查詢語句並返回集合列表</para> /// <para>返回TIn 泛型集合對象</para> /// </summary> /// <typeparam name="TIn">返回映射泛型</typeparam> /// <param name="sql">The SQL.</param> /// <returns></returns> public List<TIn> ExecSelectSqlToList<TIn>(string sql) { return context.Database.SqlQuery<TIn>(sql).ToList(); } /// <summary> /// Executes the select SQL to list. /// <para>執行查詢語句並返回集合列表</para> /// <para>返回TIn 泛型集合對象</para> /// </summary> /// <typeparam name="TIn">返回映射泛型</typeparam> /// <param name="sql">The SQL.</param> /// <param name="parameters">The parameters.</param> /// <returns></returns> public List<TIn> ExecSelectSqlToList<TIn>(string sql, params object[] parameters) { return context.Database.SqlQuery<TIn>(sql, parameters).ToList(); } /// <summary> /// Executes the command SQL /// <para>執行命令的SQL</para> /// </summary> /// <typeparam name="TIn">The type of the in.</typeparam> /// <param name="sql">The SQL.</param> /// <param name="parameters">The parameters.</param> /// <returns></returns> public int ExecCommandSql<TIn>(string sql, params object[] parameters) { return context.Database.ExecuteSqlCommand(sql, parameters); } /// <summary> /// 根據主鍵批量物理刪除 /// </summary> /// <param name="where">where條件</param> /// <returns></returns> public IBusinessResponse<bool> Remove(Expression<Func<T, bool>> where) { return this.Remove(GetQueryable(where)); } /// <summary> /// 根據主鍵批量物理刪除 /// </summary> /// <param name="queryable">可查詢對象</param> /// <returns></returns> public IBusinessResponse<bool> Remove(IQueryable<T> queryable) { var rowNumber = queryable.Delete(); if (rowNumber == 0) { return new BusinessResponse<bool>(false, "刪除失敗", "Not_Row", false); } return new BusinessResponse<bool>(true, "刪除成功", "Success", true); } }