DatabaseTableService.cs 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. using Attribute;
  2. using Model;
  3. using Model.Base;
  4. using Repository;
  5. using Service;
  6. using Microsoft.AspNetCore.Mvc;
  7. using Vo.Admin;
  8. namespace Services
  9. {
  10. /// <summary>
  11. /// 数据表Service业务层处理
  12. /// </summary>
  13. [AppService(ServiceType = typeof(IDatabaseTableService), ServiceLifetime = LifeTime.Transient)]
  14. public class DatabaseTableService : BaseService<DatabaseTable>, IDatabaseTableService
  15. {
  16. /// <summary>
  17. /// 数据表-列表
  18. /// </summary>
  19. /// <param name="param">参数请求体</param>
  20. /// <param name="page">分页参数</param>
  21. /// <returns>列表</returns>
  22. public PagedInfo<GetDatabaseTableListVo> getDatabaseTableList([FromQuery] PagerInfo page, [FromQuery] DatabaseTable param)
  23. {
  24. //拼装查询条件
  25. var predicate = Expressionable.Create<DatabaseTable>();
  26. predicate = predicate.AndIF(param.databaseId > 0, m => m.databaseId == param.databaseId);
  27. predicate = predicate.AndIF(!string.IsNullOrEmpty(param.tableTitle), m => m.tableTitle.Contains(param.tableTitle));
  28. predicate = predicate.AndIF(!string.IsNullOrEmpty(param.tableName), m => m.tableName.Contains(param.tableName));
  29. predicate = predicate.AndIF(param.splitKind > 0, m => m.splitKind == param.splitKind);
  30. var response = Queryable()
  31. .Where(predicate.ToExpression())
  32. .OrderByDescending(m => m.id)
  33. .ToPage<DatabaseTable, GetDatabaseTableListVo>(page);
  34. return response;
  35. }
  36. }
  37. }