|  |  |  | 
|---|
|  |  |  | public ISqlSugarClient Db => BaseDal.Db; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private PropertyInfo[] _propertyInfo { get; set; } = null; | 
|---|
|  |  |  | private PropertyInfo[] TProperties | 
|---|
|  |  |  | public PropertyInfo[] TProperties | 
|---|
|  |  |  | { | 
|---|
|  |  |  | get | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | if (expressionType == LinqExpressionType.Equal) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (string.IsNullOrEmpty(where)) | 
|---|
|  |  |  | where += $"{searchParametersList[i].Name} like '%{searchParametersList[i].Value}%'"; | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 针对字符串类型的字段使用模糊查询 | 
|---|
|  |  |  | //where += $"{searchParametersList[i].Name} like '%{searchParametersList[i].Value}%'"; | 
|---|
|  |  |  | if (searchParametersList[i].Value.ToLower() == "true" || searchParametersList[i].Value.ToLower() == "false") | 
|---|
|  |  |  | { | 
|---|
|  |  |  | where += $" {searchParametersList[i].Name} = '{searchParametersList[i].Value.ToLower()}'"; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | where += $"{searchParametersList[i].Name} like '%{searchParametersList[i].Value}%'"; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | where += $" and {searchParametersList[i].Name} like '%{searchParametersList[i].Value}%'"; | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 针对布尔类型字段进行精确查询 | 
|---|
|  |  |  | if (searchParametersList[i].Value.ToLower() == "true" || searchParametersList[i].Value.ToLower() == "false") | 
|---|
|  |  |  | { | 
|---|
|  |  |  | where += $" and {searchParametersList[i].Name} = '{searchParametersList[i].Value.ToLower()}'"; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | where += $" and {searchParametersList[i].Name} like '%{searchParametersList[i].Value}%'"; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | /// <param name="pageData"></param> | 
|---|
|  |  |  | /// <param name="propertyInfo"></param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | private Dictionary<string, OrderByType> GetPageDataSort(PageDataOptions pageData, PropertyInfo[] propertyInfo) | 
|---|
|  |  |  | public Dictionary<string, OrderByType> GetPageDataSort(PageDataOptions pageData, PropertyInfo[] propertyInfo) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (!string.IsNullOrEmpty(pageData.Sort)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return sortDic; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else if (propertyInfo.Any(x => x.Name == pageData.Sort)) | 
|---|
|  |  |  | else if (propertyInfo.Any(x => x.Name.ToUpper() == pageData.Sort.ToUpper())) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return new Dictionary<string, OrderByType> { | 
|---|
|  |  |  | { | 
|---|
|  |  |  | pageData.Sort,pageData.Order?.ToLower() == OrderByType.Asc.ToString() ? OrderByType.Asc : OrderByType.Desc | 
|---|
|  |  |  | pageData.Sort,pageData.Order?.ToLower() == OrderByType.Asc.ToString().ToLower()? OrderByType.Asc : OrderByType.Desc | 
|---|
|  |  |  | } }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|