You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

378 lines
14 KiB
C#

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

using Admin.Core.IRepository;
using Admin.Core.IService;
using Admin.Core.Model;
using Admin.Core.Model.Model_New;
using Castle.DynamicProxy.Generators.Emitters.SimpleAST;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq.Expressions;
using System.Threading.Tasks;
namespace Admin.Core.Service
{
public class BaseServices<TEntity> : IBaseServices<TEntity> where TEntity : class, new()
{
//public IBaseRepository<TEntity> baseDal = new BaseRepository<TEntity>();
public IBaseRepository<TEntity> BaseDal { get; set; }//通过在子类的构造函数中注入,这里是基类,不用构造函数
public bool GetConnectionState()
{
return BaseDal.GetConnectionState();
}
/// <summary>
/// 正序查询第一条数据
/// </summary>
/// <returns></returns>
public async Task<TEntity> FirstAsync()
{
if (BaseDal.GetConnectionState() == false) return null;
return await BaseDal.FirstAsync();
}
/// <summary>
/// 根据条件查询查询第一条数据
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
public async Task<TEntity> FirstAsync(Expression<Func<TEntity, bool>> whereExpression)
{
if (BaseDal.GetConnectionState() == false) return null;
return await BaseDal.FirstAsync(whereExpression);
}
public async Task<TEntity> QueryByIdAsync(object objId)
{
if (BaseDal.GetConnectionState() == false) return null;
return await BaseDal.QueryByIdAsync(objId);
}
/// <summary>
/// 功能描述:根据ID查询一条数据
/// 作  者:Admin.Core
/// </summary>
/// <param name="objId">id必须指定主键特性 [SugarColumn(IsPrimaryKey=true)]如果是联合主键请使用Where条件</param>
/// <param name="blnUseCache">是否使用缓存</param>
/// <returns>数据实体</returns>
public async Task<TEntity> QueryByIdAsync(object objId, bool blnUseCache = false)
{
if (BaseDal.GetConnectionState() == false) return null;
return await BaseDal.QueryByIdAsync(objId, blnUseCache);
}
/// <summary>
/// 功能描述:根据ID查询数据
/// 作  者:Admin.Core
/// </summary>
/// <param name="lstIds">id列表必须指定主键特性 [SugarColumn(IsPrimaryKey=true)]如果是联合主键请使用Where条件</param>
/// <returns>数据实体列表</returns>
public async Task<List<TEntity>> QueryByIDsAsync(object[] lstIds)
{
if (BaseDal.GetConnectionState() == false) return null;
return await BaseDal.QueryByIDsAsync(lstIds);
}
/// <summary>
/// 写入实体数据
/// </summary>
/// <param name="entity">实体类</param>
/// <returns></returns>
public async Task<int> AddAsync(TEntity entity)
{
return await BaseDal.AddAsync(entity);
}
/// <summary>
/// 批量插入实体(速度快)
/// </summary>
/// <param name="listEntity">实体集合</param>
/// <returns>影响行数</returns>
public async Task<int> AddAsync(List<TEntity> listEntity)
{
return await BaseDal.AddAsync(listEntity);
}
/// <summary>
/// 更新实体数据
/// </summary>
/// <param name="entity">实体类</param>
/// <returns></returns>
public async Task<bool> UpdateAsync(TEntity entity)
{
return await BaseDal.UpdateAsync(entity);
}
public async Task<bool> UpdateAsync(TEntity entity, string strWhere)
{
return await BaseDal.UpdateAsync(entity, strWhere);
}
public async Task<bool> UpdateAsync(object operateAnonymousObjects)
{
return await BaseDal.UpdateAsync(operateAnonymousObjects);
}
public async Task<bool> UpdateAsync(
TEntity entity,
List<string> lstColumns = null,
List<string> lstIgnoreColumns = null,
string strWhere = ""
)
{
return await BaseDal.UpdateAsync(entity, lstColumns, lstIgnoreColumns, strWhere);
}
/// <summary>
/// 根据实体删除一条数据
/// </summary>
/// <param name="entity">实体类</param>
/// <returns></returns>
public async Task<bool> DeleteAsync(TEntity entity)
{
return await BaseDal.DeleteAsync(entity);
}
/// <summary>
/// 删除指定ID的数据
/// </summary>
/// <param name="id">主键ID</param>
/// <returns></returns>
public async Task<bool> DeleteByIdAsync(object id)
{
return await BaseDal.DeleteByIdAsync(id);
}
/// <summary>
/// 删除指定ID集合的数据(批量删除)
/// </summary>
/// <param name="ids">主键ID集合</param>
/// <returns></returns>
public async Task<bool> DeletesAsync(List<TEntity> entitys)
{
return await BaseDal.DeletesAsync(entitys);
}
/// <summary>
/// 功能描述:查询所有数据
/// 作  者:Admin.Core
/// </summary>
/// <returns>数据列表</returns>
public async Task<List<TEntity>> QueryAsync()
{
return await BaseDal.QueryAsync();
}
/// <summary>
/// 功能描述:查询数据列表
/// 作  者:Admin.Core
/// </summary>
/// <param name="strWhere">条件</param>
/// <returns>数据列表</returns>
public async Task<List<TEntity>> QueryAsync(string strWhere)
{
return await BaseDal.QueryAsync(strWhere);
}
/// <summary>
/// 功能描述:查询数据列表
/// 作  者:Admin.Core
/// </summary>
/// <param name="whereExpression">whereExpression</param>
/// <returns>数据列表</returns>
public async Task<List<TEntity>> QueryAsync(Expression<Func<TEntity, bool>> whereExpression)
{
return await BaseDal.QueryAsync(whereExpression);
}
/// <summary>
/// 功能描述:按照特定列查询数据列表
/// 作  者:Admin.Core
/// </summary>
/// <typeparam name="TResult"></typeparam>
/// <param name="expression"></param>
/// <returns></returns>
public async Task<List<TResult>> QueryAsync<TResult>(Expression<Func<TEntity, TResult>> expression)
{
return await BaseDal.QueryAsync(expression);
}
/// <summary>
/// 功能描述:按照特定列查询数据列表带条件排序
/// 作  者:Admin.Core
/// </summary>
/// <typeparam name="TResult"></typeparam>
/// <param name="whereExpression">过滤条件</param>
/// <param name="expression">查询实体条件</param>
/// <param name="strOrderByFileds">排序条件</param>
/// <returns></returns>
public async Task<List<TResult>> QueryAsync<TResult>(Expression<Func<TEntity, TResult>> expression, Expression<Func<TEntity, bool>> whereExpression, string strOrderByFileds)
{
return await BaseDal.QueryAsync(expression, whereExpression, strOrderByFileds);
}
/// <summary>
/// 功能描述:查询一个列表
/// 作  者:Admin.Core
/// </summary>
/// <param name="whereExpression">条件表达式</param>
/// <param name="strOrderByFileds">排序字段如name asc,age desc</param>
/// <returns>数据列表</returns>
public async Task<List<TEntity>> QueryAsync(Expression<Func<TEntity, bool>> whereExpression, Expression<Func<TEntity, object>> orderByExpression, bool isAsc = true)
{
return await BaseDal.QueryAsync(whereExpression, orderByExpression, isAsc);
}
public async Task<List<TEntity>> QueryAsync(Expression<Func<TEntity, bool>> whereExpression, string strOrderByFileds)
{
return await BaseDal.QueryAsync(whereExpression, strOrderByFileds);
}
/// <summary>
/// 功能描述:查询一个列表
/// 作  者:Admin.Core
/// </summary>
/// <param name="strWhere">条件</param>
/// <param name="strOrderByFileds">排序字段如name asc,age desc</param>
/// <returns>数据列表</returns>
public async Task<List<TEntity>> QueryAsync(string strWhere, string strOrderByFileds)
{
return await BaseDal.QueryAsync(strWhere, strOrderByFileds);
}
/// <summary>
/// 根据sql语句查询
/// </summary>
/// <param name="strSql">完整的sql语句</param>
/// <param name="parameters">参数</param>
/// <returns>泛型集合</returns>
public async Task<List<TEntity>> QuerySqlAsync(string strSql, SugarParameter[] parameters = null)
{
return await BaseDal.QuerySqlAsync(strSql, parameters);
}
/// <summary>
/// 执行sql语句
/// </summary>
/// <param name="strSql">完整的sql语句</param>
/// <param name="parameters">参数</param>
/// <returns>泛型集合</returns>
public async Task<int> ExecSqlAsync(string strSql, SugarParameter[] parameters = null)
{
return await BaseDal.ExecSqlAsync(strSql, parameters);
}
/// <summary>
/// 根据sql语句查询
/// </summary>
/// <param name="strSql">完整的sql语句</param>
/// <param name="parameters">参数</param>
/// <returns>DataTable</returns>
public async Task<DataTable> QueryTableAsync(string strSql, SugarParameter[] parameters = null)
{
return await BaseDal.QueryTableAsync(strSql, parameters);
}
/// <summary>
/// 功能描述:查询前N条数据
/// 作  者:Admin.Core
/// </summary>
/// <param name="whereExpression">条件表达式</param>
/// <param name="intTop">前N条</param>
/// <param name="strOrderByFileds">排序字段如name asc,age desc</param>
/// <returns>数据列表</returns>
public async Task<List<TEntity>> QueryAsync(Expression<Func<TEntity, bool>> whereExpression, int intTop, string strOrderByFileds)
{
return await BaseDal.QueryAsync(whereExpression, intTop, strOrderByFileds);
}
/// <summary>
/// 功能描述:查询前N条数据
/// 作  者:Admin.Core
/// </summary>
/// <param name="strWhere">条件</param>
/// <param name="intTop">前N条</param>
/// <param name="strOrderByFileds">排序字段如name asc,age desc</param>
/// <returns>数据列表</returns>
public async Task<List<TEntity>> QueryAsync(
string strWhere,
int intTop,
string strOrderByFileds)
{
return await BaseDal.QueryAsync(strWhere, intTop, strOrderByFileds);
}
/// <summary>
/// 功能描述:分页查询
/// 作  者:Admin.Core
/// </summary>
/// <param name="whereExpression">条件表达式</param>
/// <param name="intPageIndex">页码下标0</param>
/// <param name="intPageSize">页大小</param>
/// <param name="strOrderByFileds">排序字段如name asc,age desc</param>
/// <returns>数据列表</returns>
public async Task<List<TEntity>> QueryAsync(
Expression<Func<TEntity, bool>> whereExpression,
int intPageIndex,
int intPageSize,
string strOrderByFileds)
{
return await BaseDal.QueryAsync(
whereExpression,
intPageIndex,
intPageSize,
strOrderByFileds);
}
/// <summary>
/// 功能描述:分页查询
/// 作  者:Admin.Core
/// </summary>
/// <param name="strWhere">条件</param>
/// <param name="intPageIndex">页码下标0</param>
/// <param name="intPageSize">页大小</param>
/// <param name="strOrderByFileds">排序字段如name asc,age desc</param>
/// <returns>数据列表</returns>
public async Task<List<TEntity>> QueryAsync(
string strWhere,
int intPageIndex,
int intPageSize,
string strOrderByFileds)
{
return await BaseDal.QueryAsync(
strWhere,
intPageIndex,
intPageSize,
strOrderByFileds);
}
public async Task<PageModel<TEntity>> QueryPageAsync(Expression<Func<TEntity, bool>> whereExpression,
int intPageIndex = 1, int intPageSize = 20, string strOrderByFileds = null)
{
return await BaseDal.QueryPageAsync(whereExpression,
intPageIndex, intPageSize, strOrderByFileds);
}
public async Task<List<TResult>> QueryMuchAsync<T, T2, T3, TResult>(Expression<Func<T, T2, T3, object[]>> joinExpression, Expression<Func<T, T2, T3, TResult>> selectExpression, Expression<Func<T, T2, T3, bool>> whereLambda = null) where T : class, new()
{
return await BaseDal.QueryMuchAsync(joinExpression, selectExpression, whereLambda);
}
/// <summary>
/// 同步
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
public List<TEntity> Query(Expression<Func<TEntity, bool>> whereExpression)
{
return BaseDal.Query(whereExpression);
}
}
}