using Attribute;
using Model;
using Model.Base;
using Repository;
using Service;
using Microsoft.AspNetCore.Mvc;
using Vo.Admin;
namespace Services
{
///
/// 数据表Service业务层处理
///
[AppService(ServiceType = typeof(IDatabaseTableService), ServiceLifetime = LifeTime.Transient)]
public class DatabaseTableService : BaseService, IDatabaseTableService
{
///
/// 数据表-列表
///
/// 参数请求体
/// 分页参数
/// 列表
public PagedInfo getDatabaseTableList([FromQuery] PagerInfo page, [FromQuery] DatabaseTable param)
{
//拼装查询条件
var predicate = Expressionable.Create();
predicate = predicate.AndIF(param.databaseId > 0, m => m.databaseId == param.databaseId);
predicate = predicate.AndIF(!string.IsNullOrEmpty(param.tableTitle), m => m.tableTitle.Contains(param.tableTitle));
predicate = predicate.AndIF(!string.IsNullOrEmpty(param.tableName), m => m.tableName.Contains(param.tableName));
predicate = predicate.AndIF(param.splitKind > 0, m => m.splitKind == param.splitKind);
var response = Queryable()
.Where(predicate.ToExpression())
.OrderByDescending(m => m.id)
.ToPage(page);
return response;
}
}
}