在业务开发中,一个常用的功能就是“高级查询”,就是客户可以根据自己的需要设置查询条件查找数据,类似下图:
通常,我们需要为每个“高级查询”定制Dto类,用于传输条件,并要根据条件组合成查询语句执行数据库查询操作,费时费力。
现在,使用AutoFilterer.Generators
可以轻松实现上述功能。
Demo
创建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
提供了很便利的方式实现“高级查询”,如果大家有类似的业务需求,赶快试用一下吧。
欢迎关注我的个人公众号”My IO“