MeiRiYiCheng_1_old/Plugin/YB.DeviceStand/YB.DeviceStand.SqlSugar/Repositories/ISqlSugarRepository.cs

409 lines
13 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq.Expressions;
using System.Threading.Tasks;
namespace SqlSugar
{
/// <summary>
/// 非泛型 SqlSugar 仓储
/// </summary>
public partial interface ISqlSugarRepository
{
/// <summary>
/// 切换仓储
/// </summary>
/// <typeparam name="TEntity">实体类型</typeparam>
/// <returns>仓储</returns>
ISqlSugarRepository<TEntity> Change<TEntity>()
where TEntity : class, new();
}
/// <summary>
/// SqlSugar 仓储接口定义
/// </summary>
/// <typeparam name="TEntity"></typeparam>
public partial interface ISqlSugarRepository<TEntity>
where TEntity : class, new()
{
/// <summary>
/// 实体集合
/// </summary>
ISugarQueryable<TEntity> Entities { get; }
/// <summary>
/// 数据库上下文
/// </summary>
SqlSugarClient Context { get; }
/// <summary>
/// 动态数据库上下文
/// </summary>
dynamic DynamicContext { get; }
/// <summary>
/// 原生 Ado 对象
/// </summary>
IAdo Ado { get; }
/// <summary>
/// 获取总数
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
int Count(Expression<Func<TEntity, bool>> whereExpression);
/// <summary>
/// 获取总数
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
Task<int> CountAsync(Expression<Func<TEntity, bool>> whereExpression);
/// <summary>
/// 检查是否存在
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
bool Any(Expression<Func<TEntity, bool>> whereExpression);
/// <summary>
/// 检查是否存在
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
Task<bool> AnyAsync(Expression<Func<TEntity, bool>> whereExpression);
/// <summary>
/// 通过主键获取实体
/// </summary>
/// <param name="Id"></param>
/// <returns></returns>
TEntity Single(dynamic Id);
/// <summary>
/// 获取一个实体
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
TEntity Single(Expression<Func<TEntity, bool>> whereExpression);
/// <summary>
/// 获取一个实体
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
Task<TEntity> SingleAsync(Expression<Func<TEntity, bool>> whereExpression);
/// <summary>
/// 获取一个实体
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
TEntity FirstOrDefault(Expression<Func<TEntity, bool>> whereExpression);
/// <summary>
/// 获取一个实体
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
Task<TEntity> FirstOrDefaultAsync(Expression<Func<TEntity, bool>> whereExpression);
/// <summary>
/// 获取列表
/// </summary>
/// <returns></returns>
List<TEntity> ToList();
/// <summary>
/// 获取列表
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
List<TEntity> ToList(Expression<Func<TEntity, bool>> whereExpression);
/// <summary>
/// 获取列表
/// </summary>
/// <param name="whereExpression"></param>
/// <param name="orderByExpression"></param>
/// <param name="orderByType"></param>
/// <returns></returns>
List<TEntity> ToList(Expression<Func<TEntity, bool>> whereExpression, Expression<Func<TEntity, object>> orderByExpression = null, OrderByType orderByType = OrderByType.Asc);
/// <summary>
/// 获取列表
/// </summary>
/// <returns></returns>
Task<List<TEntity>> ToListAsync();
/// <summary>
/// 获取列表
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
Task<List<TEntity>> ToListAsync(Expression<Func<TEntity, bool>> whereExpression);
/// <summary>
/// 获取列表
/// </summary>
/// <param name="whereExpression"></param>
/// <param name="orderByExpression"></param>
/// <param name="orderByType"></param>
/// <returns></returns>
Task<List<TEntity>> ToListAsync(Expression<Func<TEntity, bool>> whereExpression, Expression<Func<TEntity, object>> orderByExpression = null, OrderByType orderByType = OrderByType.Asc);
/// <summary>
/// 新增一条记录
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
int Insert(TEntity entity);
/// <summary>
/// 新增多条记录
/// </summary>
/// <param name="entities"></param>
/// <returns></returns>
int Insert(params TEntity[] entities);
/// <summary>
/// 新增多条记录
/// </summary>
/// <param name="entities"></param>
/// <returns></returns>
int Insert(IEnumerable<TEntity> entities);
/// <summary>
/// 新增一条记录返回自增Id
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
int InsertReturnIdentity(TEntity entity);
/// <summary>
/// 新增一条记录
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
Task<int> InsertAsync(TEntity entity);
/// <summary>
/// 新增多条记录
/// </summary>
/// <param name="entities"></param>
/// <returns></returns>
Task<int> InsertAsync(params TEntity[] entities);
/// <summary>
/// 新增多条记录
/// </summary>
/// <param name="entities"></param>
/// <returns></returns>
Task<int> InsertAsync(IEnumerable<TEntity> entities);
/// <summary>
/// 新增一条记录返回自增Id
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
Task<long> InsertReturnIdentityAsync(TEntity entity);
/// <summary>
/// 更新一条记录
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
int Update(TEntity entity);
/// <summary>
/// 更新多条记录
/// </summary>
/// <param name="entities"></param>
/// <returns></returns>
int Update(params TEntity[] entities);
/// <summary>
/// 更新多条记录
/// </summary>
/// <param name="entities"></param>
/// <returns></returns>
int Update(IEnumerable<TEntity> entities);
/// <summary>
/// 更新一条记录
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
Task<int> UpdateAsync(TEntity entity);
/// <summary>
/// 无主键更新一条记录
/// </summary>
/// <param name="entity">更新的实体</param>
/// <param name="columns">根据那些字段更新</param>
/// <returns></returns>
Task<int> UpdateNoPrimaryKey(TEntity entity, Expression<Func<TEntity, object>> columns);
/// <summary>
/// 无主键更新多条记录
/// </summary>
/// <param name="entity">更新的实体</param>
/// <param name="columns">根据那些字段更新</param>
/// <returns></returns>
Task<int> UpdateNoPrimaryKeyAsync(List<TEntity> entitys, Expression<Func<TEntity, object>> columns);
/// <summary>
/// 无主键更新多条记录
/// </summary>
/// <param name="entity">更新的实体</param>
/// <param name="columns">根据那些字段更新</param>
/// <returns></returns>
Task<int> UpdateNoPrimaryKey(List<TEntity> entitys, Expression<Func<TEntity, object>> columns);
/// <summary>
/// 无主键更新一条记录
/// </summary>
/// <param name="entity">更新的实体</param>
/// <param name="columns">根据那些字段更新</param>
/// <returns></returns>
Task<int> UpdateNoPrimaryKeyAsync(TEntity entity, Expression<Func<TEntity, object>> columns);
/// <summary>
/// 更新多条记录
/// </summary>
/// <param name="entities"></param>
/// <returns></returns>
Task<int> UpdateAsync(params TEntity[] entities);
/// <summary>
/// 更新多条记录
/// </summary>
/// <param name="entities"></param>
/// <returns></returns>
Task<int> UpdateAsync(IEnumerable<TEntity> entities);
/// <summary>
/// 删除一条记录
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
int Delete(TEntity entity);
/// <summary>
/// 删除一条记录
/// </summary>
/// <param name="key"></param>
/// <returns></returns>
int Delete(object key);
/// <summary>
/// 删除多条记录
/// </summary>
/// <param name="keys"></param>
/// <returns></returns>
int Delete(params object[] keys);
/// <summary>
/// 自定义条件删除记录
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
int Delete(Expression<Func<TEntity, bool>> whereExpression);
/// <summary>
/// 删除一条记录
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
Task<int> DeleteAsync(TEntity entity);
/// <summary>
/// 删除一条记录
/// </summary>
/// <param name="key"></param>
/// <returns></returns>
Task<int> DeleteAsync(object key);
/// <summary>
/// 删除多条记录
/// </summary>
/// <param name="keys"></param>
/// <returns></returns>
Task<int> DeleteAsync(params object[] keys);
/// <summary>
/// 自定义条件删除记录
/// </summary>
/// <param name="whereExpression"></param>
/// <returns></returns>
Task<int> DeleteAsync(Expression<Func<TEntity, bool>> whereExpression);
bool IsExists(Expression<Func<TEntity, bool>> whereExpression);
Task<bool> IsExistsAsync(Expression<Func<TEntity, bool>> whereExpression);
/// <summary>
/// 根据表达式查询多条记录
/// </summary>
/// <param name="predicate"></param>
/// <returns></returns>
ISugarQueryable<TEntity> Where(Expression<Func<TEntity, bool>> predicate);
/// <summary>
/// 根据表达式查询多条记录
/// </summary>
/// <param name="condition"></param>
/// <param name="predicate"></param>
/// <returns></returns>
ISugarQueryable<TEntity> Where(bool condition, Expression<Func<TEntity, bool>> predicate);
/// <summary>
/// 构建查询分析器
/// </summary>
/// <returns></returns>
ISugarQueryable<TEntity> AsQueryable();
/// <summary>
/// 构建查询分析器
/// </summary>
/// <param name="predicate"></param>
/// <returns></returns>
ISugarQueryable<TEntity> AsQueryable(Expression<Func<TEntity, bool>> predicate);
/// <summary>
/// 直接返回数据库结果
/// </summary>
/// <returns></returns>
List<TEntity> AsEnumerable();
/// <summary>
/// 直接返回数据库结果
/// </summary>
/// <param name="predicate"></param>
/// <returns></returns>
List<TEntity> AsEnumerable(Expression<Func<TEntity, bool>> predicate);
/// <summary>
/// 直接返回数据库结果
/// </summary>
/// <returns></returns>
Task<List<TEntity>> AsAsyncEnumerable();
/// <summary>
/// 直接返回数据库结果
/// </summary>
/// <param name="predicate"></param>
/// <returns></returns>
Task<List<TEntity>> AsAsyncEnumerable(Expression<Func<TEntity, bool>> predicate);
/// <summary>
/// 切换仓储
/// </summary>
/// <typeparam name="TChangeEntity"></typeparam>
/// <returns></returns>
ISqlSugarRepository<TChangeEntity> Change<TChangeEntity>() where TChangeEntity : class, new();
}
}