您好,登录后才能下订单哦!
这篇文章将为大家详细讲解有关ynamic LINQ如何创建高级查询服务,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
在业务开发中,一个常用的功能就是“高级查询”,就是客户可以根据自己的需要设置查询条件查找数据,类似下图:
通常,我们需要为每个“高级查询”定制Dto类,用于传输条件,并要根据条件组合成查询语句执行数据库查询操作,费时费力。
现在,使用AutoFilterer.Generators可以轻松实现上述功能。
举例:
创建Asp.Net Core Web API
项目,引用Nuget包AutoFilterer.Generators。
在WeatherForecast
类上添加GenerateAutoFilterAttribute
:
[GenerateAutoFilter] public class WeatherForecast { public DateTime Date { get; set; } public int TemperatureC { get; set; } public int TemperatureF => 32 + (int)(TemperatureC / 0.5556); public string Summary { get; set; } }
然后,修改WeatherForecastController.cs
的Get方法,增加WeatherForecastFilter
参数:
[HttpGet]:
public IEnumerable<WeatherForecast> Get([FromQuery]WeatherForecastFilter filter) { var rng = new Random(); // Change range to 100 from 5 to get more reasonable results. return Enumerable.Range(1, 100).Select(index => new WeatherForecast { Date = DateTime.Now.AddDays(index), TemperatureC = rng.Next(-20, 55), Summary = Summaries[rng.Next(Summaries.Length)] }) .AsQueryable().ApplyFilter(filter)//使用filter .ToArray(); }
AutoFilterer.Generators提供了IQueryable.ApplyFilter(filter)扩展方法,可以根据高级查询条件进行数据筛选。
运行程序,可以在Swagger UI看到如下图:
现在,“高级查询”服务已经完成了。你可以传入最小最大值范围,排序方式,分页方式。
结论:
AutoFilterer.Generators提供了很便利的方式实现“高级查询”,如果大家有类似的业务需求,可以试一下
但是,AutoFilterer.Generators只能提供简单的范围筛选:
今天,我们介绍如何使用Dynamic LINQ轻松实现更强大的高级查询服务。
举例:
创建ASP.NET Core Web API项目,引用Nuget包System.Linq.Dynamic.Core。
并在WeatherForecastController.cs头部添加:
using System.Linq.Dynamic.Core;
创建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; } }
修改默认的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页面能显示正确:
上面最关键的代码是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(); } }
运行程序,传入指定的参数并执行:
可以看到,现在,“高级查询”服务已经完成了:
关于“ynamic LINQ如何创建高级查询服务”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。