entity framework 封裝基類

/// <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);
}

 

}
相關文章
相關標籤/搜索