武装你的WEBAPI-OData入门

本文属于OData系列html

目录(可能会有后续修改)前端

  • 武装你的WEBAPI-OData入门
  • 武装你的WEBAPI-OData便捷查询
  • 武装你的WEBAPI-OData分页查询
  • 武装你的WEBAPI-OData资源更新
  • 武装你的WEBAPI-OData之EDM
  • 武装你的WEBAPI-OData格式转换
  • 武装你的WEBAPI-OData使用Endpoint

EDM EDEDM EDM EDEDM!git

前阵子刷抖音,隔几个就是这个,被洗脑了,本着闲着也是闲着的心态,我决定一探究竟,唱的究竟是个啥。github

探索

网上找了一下,发现这个:EDM is short for Entity Data Model.shell

看到这个我就惊了,这不就是OData的数据模型嘛,我去,他们还挺有极客精神。想到前阵子也用OData来着,就简单写写相关的内容吧。数据库

OData简介

什么是OData?c#

OData(Open Data Protocol)是一个开源的开放协议(OASIS标准)的技术,开发者能够经过它向用户提供可查询的API。(官方网站后端

很笼统,咱们直接看这个玩意能够干什么:api

  • 客户端能够经过请求自行设计查询,不须要和后端沟通具体查询参数、接口等信息,节省了大量的沟通成本和时间成本。
  • 数据的筛选是在服务端完成的,不须要客户端一次性请求全部数据并在前端筛选,大大提高了效率。
  • 支持数据的定制,能够选择数据的多个维度。
  • 结合EF等ORM技术,数据能够直接经过数据库查询得到,效率更高。
  • 轻松实现分页查询
  • 符合RESTful

很是有吸引力,若是后端写好接口,前端本身去选数据了,想干啥干啥,别找我要传参查询,世界多美好。app

这个东西见的很少,可是确实在不少地方用到,例如SharePoint、Microsoft Graph等等,没错你猜对了,这东西就是微软和SAP出的,2007年就有了。SAP也用了不少这个,不少资料都是他们写的。和这个东西相似的有一个GraphQL,没研究过。

  • 官方的口号是OData - the best way to REST

方法

直接看看应该怎么用吧,首先你须要有一个现成的API。

安装Nuget包

Install-Package Microsoft.AspNetCore.OData

设置Startup.cs

须要在ConfigureServices里面增长

services.AddOData();

在Configure里面增长

app.UseMvc(routeBuilder => {

     routeBuilder.EnableDependencyInjection();
	 //启用EXPAND/SELECT/ORDERBY/FILTER语法支持
     routeBuilder.Expand().Select().OrderBy().Filter();

});

而后在API的方法上面添加[EnableQuery]这个内容就好了。

[HttpGet]
[EnableQuery]
public IEnumerable<Student> GetStudents()
{
    return this.context.Students;
}

简单使用

部署好了以后,就可使用GET请求来请求数据了。

Select查询

api/students?$select=Name

上面的请求将只返回学生的姓名,别的就不返回了,这样可以减小大量的数据。

Filter过滤

api/students?$filter=Name eq 'Todd'

上面的查询返回student用户名为Todd的记录。

api/students?filter=Score gt 100

上面的查询返回Score大于100的学生的记录。

OrderBy排序

api/students?$orderby=Score desc

上面的查询返回按照Score进行降序排序的记录。

总结

OData使得客户端的查询变得极其方便,本文只是开篇,还有不少更方便的特性,之后再讲。

官方示例项目:https://github.com/hassanhabib/ODataDemo

参考资料