案头见蠹鱼,犹胜凡俦侣。这篇文章主要讲述使用Dynamic LINQ创建高级查询服务 #yyds干货盘点#相关的知识,希望能为你提供帮助。
前言在以前的文章中,我们介绍了使用??AutoFilterer.Generators?
???创建高级查询服务??。
但是,??AutoFilterer.Generators?
?只能提供简单的范围筛选:
今天,我们介绍如何使用Dynamic LINQ轻松实现更强大的高级查询服务。
Demo创建ASP.NET Core Web API项目,引用Nuget包??System.Linq.Dynamic.Core?
?。
并在WeatherForecastController.cs头部添加:
using System.Linq.Dynamic.Core;
?1.定义查询参数?创建??DynamicLinqDto?
?,用于传递返回字段、查询条件、排序方式、分页方式等:
public class DynamicLinqDto
public string Fieldsget;
set;
public string Filterget;
set;
public string OrderByget;
set;
public int? PageNoget;
set;
public int? PageSizeget;
set;
?2.实现查询方法?修改默认的Get方法如下:
[HttpGet]
[ProducesDefaultResponseType(typeof(WeatherForecast))]
public IEnumerable<
dynamic>
Get([FromQuery] DynamicLinqDto dto)
var rng = new Random();
IQueryable query = Enumerable.Range(1, 5).Select(index =>
new WeatherForecast
Date = DateTime.Now.AddDays(index),
TemperatureC = rng.Next(-20, 55),
Summary = Summaries[rng.Next(Summaries.Length)]
)
.AsQueryable();
return query.ToDynamicArray(dto);
由于Get方法的返回类型是IEnumerable,因此需要使用??ProducesDefaultResponseTypeAttribute?
?指定实际返回的类型,以便Swagger页面能显示正确:
?3.实现扩展方法?上面最关键的代码是??ToDynamicArray?
?方法。
实际上,这是我们封装的扩展方法,对于任意??IQueryable?
?对象,实现高级查询:
public static class DynamicLinqExtentions
public static dynamic[] ToDynamicArray(this IQueryable query, DynamicLinqDto dto)
if (!string.IsNullOrWhiteSpace(dto.Fields))
query = query.Select($@"new(dto.Fields)");
if (!string.IsNullOrWhiteSpace(dto.Filter))
query = query.Where(dto.Filter);
if (!string.IsNullOrWhiteSpace(dto.OrderBy))
query = query.OrderBy(dto.OrderBy);
var pageNo = dto.PageNo ?? 1;
var pageSize = dto.PageSize ?? 10;
query = query.Page(pageNo, pageSize);
return query.ToDynamicArray();
?4.效果?运行程序,传入指定的参数并执行:
可以看到,现在,“高级查询”服务已经完成了:
结论可以看到Dynamic LINQ LINQ 使实现起来相当容易。详细参数说明请参看官方文档:https://dynamic-linq.net/
想了解更多内容,请关注我的个人公众号”My IO“?
【使用Dynamic LINQ创建高级查询服务 #yyds干货盘点#】
推荐阅读
- DataOps是“数据的DevOps”吗()
- 快速使用linux系统指令
- FAQ接入HMS Core应用内支付服务过程中一些常见问题总结
- #yyds干货盘点#高级IO模型之kqueue和epoll
- 微信小程序环境共享,多个小程序共享一个云开发数据库
- #yyds干货盘点#Git学习-如何修改已经提交的记录
- Java8新特性Optional类在处理空值判断场景的应用 回避空指针异常 编写健壮的应用程序
- docker 批量删除 none 镜像
- #yyds干货盘点#在element-ui中使用dialog的时候只有遮罩,看不见内容的问题