使用Dynamic LINQ创建高级查询服务 #yyds干货盘点#

Posted My空格IO

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用Dynamic LINQ创建高级查询服务 #yyds干货盘点#相关的知识,希望对你有一定的参考价值。

前言

在以前的文章中,我们介绍了使用​​AutoFilterer.Generators​​​​创建高级查询服务​​。

但是,​​AutoFilterer.Generators​​只能提供简单的范围筛选:

使用Dynamic

今天,我们介绍如何使用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 Fields get; set;

public string Filter get; set;

public string OrderBy get; set;

public int? PageNo get; set;

public int? PageSize get; 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页面能显示正确:

使用Dynamic

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

可以看到,现在,“高级查询”服务已经完成了:

使用Dynamic

结论

可以看到Dynamic LINQ LINQ 使实现起来相当容易。详细参数说明请参看官方文档:https://dynamic-linq.net/

想了解更多内容,请关注我的个人公众号”My IO“

使用Dynamic


以上是关于使用Dynamic LINQ创建高级查询服务 #yyds干货盘点#的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Dynamic Linq Core 中无任何分组

动态对象,可持久保存到 Azure 并可通过 Dynamic Linq 查询

对linq查询结果进行去重处理

System.Linq.Dynamic.Core - 查询嵌套对象

System.Linq.Dynamic的使用

LINQ to SQL查询中的C#Dynamic WHERE子句