using System.Collections.Generic;
using System.Data;
using System.Linq.Expressions;
using AgileObjects.AgileMapper;
using SqlSugar;
using Tiobon.Core.Common;
using Tiobon.Core.Common.Helper;
using Tiobon.Core.Common.UserManager;
using Tiobon.Core.IRepository.Base;
using Tiobon.Core.IServices.BASE;
using Tiobon.Core.Model;
namespace Tiobon.Core.Services.BASE
{
///
/// 增删改查基础服务
///
///
///
///
///
public class BaseServices : IBaseServices where TEntity : class, new()
{
public BaseServices(IBaseRepository BaseDal = null)
{
this.BaseDal = BaseDal;
}
//public IBaseRepository baseDal = new BaseRepository();
public IBaseRepository BaseDal { get; set; } //通过在子类的构造函数中注入,这里是基类,不用构造函数
public ISqlSugarClient Db => BaseDal.Db;
public async Task QueryById(object objId)
{
return await BaseDal.QueryById(objId);
}
///
/// 根据ID查询一条数据
///
/// id(必须指定主键特性 [SugarColumn(IsPrimaryKey=true)]),如果是联合主键,请使用Where条件
/// 是否使用缓存
/// 数据实体
public async Task QueryById(object objId, bool blnUseCache = false)
{
return await BaseDal.QueryById(objId, blnUseCache);
}
///
/// 根据ID查询数据
///
/// id列表(必须指定主键特性 [SugarColumn(IsPrimaryKey=true)]),如果是联合主键,请使用Where条件
/// 数据实体列表
public async Task> QueryByIDs(object[] lstIds)
{
return await BaseDal.QueryByIDs(lstIds);
}
///
/// 写入实体数据
///
/// 博文实体类
///
public async Task Add(TEntity entity)
{
var userId = UserContext.Current.User_Id;
return await BaseDal.Add(entity);
}
///
/// 批量插入实体(速度快)
///
/// 实体集合
/// 影响行数
public async Task> Add(List listEntity)
{
return await BaseDal.Add(listEntity);
}
///
/// 更新实体数据
///
/// 博文实体类
///
public async Task Update(TEntity entity)
{
return await BaseDal.Update(entity);
}
///
/// 更新实体数据
///
/// 博文实体类
///
public async Task Update(List entity)
{
return await BaseDal.Update(entity);
}
public async Task Update(TEntity entity, string where)
{
return await BaseDal.Update(entity, where);
}
public async Task Update(object operateAnonymousObjects)
{
return await BaseDal.Update(operateAnonymousObjects);
}
public async Task Update(
TEntity entity,
List lstColumns = null,
List lstIgnoreColumns = null,
string where = ""
)
{
return await BaseDal.Update(entity, lstColumns, lstIgnoreColumns, where);
}
///
/// 根据实体删除一条数据
///
/// 博文实体类
///
public async Task Delete(TEntity entity)
{
return await BaseDal.Delete(entity);
}
///
/// 删除指定ID的数据
///
/// 主键ID
///
public async Task DeleteById(object id)
{
return await BaseDal.DeleteById(id);
}
///
/// 删除指定ID集合的数据(批量删除)
///
/// 主键ID集合
///
public async Task DeleteByIds(object[] ids)
{
return await BaseDal.DeleteByIds(ids);
}
///
/// 查询所有数据
///
/// 数据列表
public async Task> Query()
{
return await BaseDal.Query();
}
///
/// 查询数据列表
///
/// 条件
/// 数据列表
public async Task> Query(string where)
{
return await BaseDal.Query(where);
}
///
/// 查询数据列表
///
/// whereExpression
/// 数据列表
public async Task> Query(Expression> whereExpression)
{
return await BaseDal.Query(whereExpression);
}
///
/// 按照特定列查询数据列表
///
///
///
///
public async Task> Query(Expression> expression)
{
return await BaseDal.Query(expression);
}
///
/// 按照特定列查询数据列表带条件排序
///
///
/// 过滤条件
/// 查询实体条件
/// 排序条件
///
public async Task> Query(Expression> expression, Expression> whereExpression, string orderByFileds)
{
return await BaseDal.Query(expression, whereExpression, orderByFileds);
}
///
/// 查询一个列表
///
/// 条件表达式
/// 排序字段,如name asc,age desc
/// 数据列表
public async Task> Query(Expression> whereExpression, Expression> orderByExpression, bool isAsc = true)
{
return await BaseDal.Query(whereExpression, orderByExpression, isAsc);
}
public async Task> Query(Expression> whereExpression, string orderByFileds)
{
return await BaseDal.Query(whereExpression, orderByFileds);
}
///
/// 查询一个列表
///
/// 条件
/// 排序字段,如name asc,age desc
/// 数据列表
public async Task> Query(string where, string orderByFileds)
{
return await BaseDal.Query(where, orderByFileds);
}
///
/// 根据sql语句查询
///
/// 完整的sql语句
/// 参数
/// 泛型集合
public async Task> QuerySql(string sql, SugarParameter[] parameters = null)
{
return await BaseDal.QuerySql(sql, parameters);
}
///
/// 根据sql语句查询
///
/// 完整的sql语句
/// 参数
/// DataTable
public async Task QueryTable(string sql, SugarParameter[] parameters = null)
{
return await BaseDal.QueryTable(sql, parameters);
}
///
/// 查询前N条数据
///
/// 条件表达式
/// 前N条
/// 排序字段,如name asc,age desc
/// 数据列表
public async Task> Query(Expression> whereExpression, int top, string orderByFileds)
{
return await BaseDal.Query(whereExpression, top, orderByFileds);
}
///
/// 查询前N条数据
///
/// 条件
/// 前N条
/// 排序字段,如name asc,age desc
/// 数据列表
public async Task> Query(
string where,
int top,
string orderByFileds)
{
return await BaseDal.Query(where, top, orderByFileds);
}
///
/// 分页查询
///
/// 条件表达式
/// 页码(下标0)
/// 页大小
/// 排序字段,如name asc,age desc
/// 数据列表
public async Task> Query(
Expression> whereExpression,
int pageIndex,
int pageSize,
string orderByFileds)
{
return await BaseDal.Query(
whereExpression,
pageIndex,
pageSize,
orderByFileds);
}
///
/// 分页查询
///
/// 条件
/// 页码(下标0)
/// 页大小
/// 排序字段,如name asc,age desc
/// 数据列表
public async Task> Query(
string where,
int pageIndex,
int pageSize,
string orderByFileds)
{
return await BaseDal.Query(
where,
pageIndex,
pageSize,
orderByFileds);
}
public async Task> QueryPage(Expression> whereExpression,
int pageIndex = 1, int pageSize = 20, string orderByFileds = null)
{
return await BaseDal.QueryPage(whereExpression,
pageIndex, pageSize, orderByFileds);
}
public async Task> QueryFilterPage([FromFilter] QueryFilter filter)
{
var data = await BaseDal.QueryFilterPage(filter);
return new PageModel(filter.PageIndex, data.dataCount, filter.PageSize, Mapper.Map(data.data).ToANew>());
}
public async Task> QueryMuch(Expression> joinExpression, Expression> selectExpression, Expression> whereLambda = null) where T : class, new()
{
return await BaseDal.QueryMuch(joinExpression, selectExpression, whereLambda);
}
public async Task> QueryPage(PaginationModel pagination)
{
var express = DynamicLinqFactory.CreateLambda(pagination.Conditions);
return await QueryPage(express, pagination.PageIndex, pagination.PageSize, pagination.OrderByFileds);
}
#region 分表
public async Task> AddSplit(TEntity entity)
{
return await BaseDal.AddSplit(entity);
}
public async Task UpdateSplit(TEntity entity, DateTime dateTime)
{
return await BaseDal.UpdateSplit(entity, dateTime);
}
///
/// 根据实体删除一条数据
///
/// 博文实体类
///
public async Task DeleteSplit(TEntity entity, DateTime dateTime)
{
return await BaseDal.DeleteSplit(entity, dateTime);
}
public async Task QueryByIdSplit(object objId)
{
return await BaseDal.QueryByIdSplit(objId);
}
public async Task> QueryPageSplit(Expression> whereExpression, DateTime beginTime, DateTime endTime,
int pageIndex = 1, int pageSize = 20, string orderByFields = null)
{
return await BaseDal.QueryPageSplit(whereExpression, beginTime, endTime,
pageIndex, pageSize, orderByFields);
}
#endregion
}
}