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