如何修改 SAP ABAP OData 模型,使其支持 $expand 操作试读版

正如本教程的开篇介绍文章SAP OData 开发教程 - 从入门到提高(包含 SEGW, RAP 和 CDP)所提到的,SAP OData 服务开发,从实现技术上来说,可以分为三大类。因此本教程也分为三大部分,分别进行介绍。本文是本教程的文章目录。

作者简介

Jerry Wang,2007 年从电子科技大学计算机专业硕士毕业后加入 SAP 成都研究院工作至今。Jerry 是 SAP 社区导师,SAP 中国技术大使。在长达 15 年的 SAP 标准产品开发生涯里,Jerry 曾经先后参与 SAP Business ByDesign, SAP CRM, SAP Cloud for Customer, SAP S/4HANA, SAP Commerce Cloud(电商云)等标准产品的研发工作。

Jerry 对 SAP OData 服务的开发,测试,发布,部署,测试,及基于各种不同 SAP 技术实现的 OData 服务的幕后技术实现细节和使用场合,均有着深入的研究。

基于 SEGW - Gateway Service Builder 的开发教程

使用 Restful ABAP Programming 编程模型(简称 RAP) 开发 OData 服务

  • 正在写作中,敬请期待

使用 SAP Cloud Application Programming 编程模型开发 OData 服务

  • 正在写作中,敬请期待

@[toc]

OData 服务里 $expand 操作的应用场景

本步骤到目前为止我们完成的 OData 模型创建,只有一个节点即 Book. 在实际的项目中,OData 模型比我们教程里出于教学目的而设计的模型复杂得多。

比如下图是 SAP CRM My Opportunities Fiori 应用的 OData 模型,可以看到模型根节点 Opportunity 能够导航到其他子节点,比如通过我们马上要在本步骤学习的 Navigation Properties(导航属性),从根节点 Opportunity 出发,可以导航到其他子节点。比如下图黄色的 Products 是导航属性之一,通过这个字段,可以导航到该 Opportunity 包含的所有 Products 数据。

如何修改 SAP ABAP OData 模型,使其支持 $expand 操作试读版_第1张图片

这种 Opportunity 与 Products 的导航从属关系,也体现在 Fiori 应用的 UI 上。My Opportunity 这个 Fiori 应用,Opportunity 的明细页面有若干个 Tab 标签页,从第二个标签页开始,每个标签页对应着 Opportunity OData 模型的一个子节点。以下图 Products 标签页为例,其包含的数据,技术上就是通过 Opportunity 根节点,借助 Products 这个 Navigation Property,导航到 OData 模型子节点 Products 所获取的。

如何修改 SAP ABAP OData 模型,使其支持 $expand 操作试读版_第2张图片

我们打开 Chrome 开发者工具 network 标签页,发现一个 HTTP 请求的 url:

GET Opportunities(guid'FA163EE5-6C3A-1ED6-9DC1-C10749724C39')?$expand=Competitors,Products,OpportunityLogSet HTTP/1.1

如何修改 SAP ABAP OData 模型,使其支持 $expand 操作试读版_第3张图片

这个 url 里,不仅请求了 guid 为 FA163EE5-6C3A-1ED6-9DC1-C10749724C39的 Opportunity 根节点的数据,还通过 OData 协议定义的 $expand 操作,在同一个 HTTP 请求里,将其子节点比如 CompetitorsProducts 等数据一并取回。

由此可见,OData 协议 $expand,其作用就是,在同一个 HTTP 请求里将根节点连同 Navigation Property 指定的子节点数据一并取回,从而减少了为实现同样的数据读取目的而耗费的 HTTP 请求个数。

下面是我们自己的 OData 服务如何支持 $expand 操作的具体步骤。

你可能感兴趣的:(如何修改 SAP ABAP OData 模型,使其支持 $expand 操作试读版)