如何查找Fiori UI上某个字段对应的底层数据库表

很多从事ABAP开发的朋友们,想必都阅读过这个文档的英文或中文版:

18 Techniques for Locating the Underlying Data of a Screen Field

在SAP GUI里查找一个屏幕字段对应的底层数据库表的18种方法

如何查找Fiori UI上某个字段对应的底层数据库表

作者是Dennis Barrett:

如何查找Fiori UI上某个字段对应的底层数据库表

到了Fiori时代,里面的很多办法都不再适用了。

本文介绍一种方法能找出Fiori UI上某字段对应的ABAP后台数据库存储表。虽然不一定足够通用,但确实能解决Jerry当时实际工作中遇到的一个问题。

这是SAP S/4HANA一个标准的Fiori应用: Product Master

如何查找Fiori UI上某个字段对应的底层数据库表

我的需求是,找到字段"Number of Goods Receipt"在后台是存储在哪张表里的。

下面是Jerry自己探索的详细步骤。

(1) 我们知道SAP UI5也是一个基于MVC的前端框架,框架支持双向绑定。在Chrome开发者工具里,找到这个UI字段绑定的模型字段名称:

NmbrOfGROrGISlipsToPrintQty

如何查找Fiori UI上某个字段对应的底层数据库表

(2) 找到该Product Master Fiori应用基于的OData服务,浏览器里输入其metadata url查看结果,找到字段NmbrOfGROrGISlipsToPrintQty的从属数据类型为:
C_ProductstorageType

如何查找Fiori UI上某个字段对应的底层数据库表

(3) 登录ABAP Development Tool,使用菜单"Open ABAP Development Object":

如何查找Fiori UI上某个字段对应的底层数据库表

把第二步找到的数据类型C_ProductstorageType,根据命名规范,将Type前面的值C_Productstorage作为关键字查询:

如何查找Fiori UI上某个字段对应的底层数据库表

排在结果列表第一位的C_PRODUCTSTORAGE, 是一个CDS view.

视图从I_ProductStroageWD里读取数据,

如何查找Fiori UI上某个字段对应的底层数据库表

I_ProductStorageWD又从I_Productstorage里读取:

如何查找Fiori UI上某个字段对应的底层数据库表

最终,I_Productstorage从数据库表MARA里读取数据。

如何查找Fiori UI上某个字段对应的底层数据库表

在这个视图的源代码里,根据第二步找到的字段名称NmbrOfGROrGISlipsToPrintQty进行搜索,立即就找到了对应的数据库表MARA里的字段为wesch:

如何查找Fiori UI上某个字段对应的底层数据库表

再到SE16里打开MARA确认一下,发现Fiori UI上看到的23.671这个字段果然存储在MARA.WESCH里,任务完成。

如何查找Fiori UI上某个字段对应的底层数据库表

更多阅读

  • Jerry的通过CDS view + Smart Template 开发Fiori应用的blog合集
  • SAP Fiori应用的三种部署方式
  • Jerry的Fiori原创文章合集
  • SAP成都C4C小李探花:浅谈Fiori Design Guidelines
  • SAP Fiori + Vue = ?
  • Fiori Fundamentals和SAP UI5 Web Components
  • 30分钟用Restful ABAP Programming模型开发一个支持增删改查的Fiori应用
  • SAP Fiori应用索引大全
  • 介绍一种Fiori标准应用的增强方式
  • 揭开SAP Fiori编程模型规范里注解的神秘面纱 - @ObjectModel.readOnly工作原理解析
  • 为什么SAP GUI里的传统事务码能通过Fiori Launchpad启动并运行在浏览器里
  • 一步步把SAP GUI的事务码配置到SAP Fiori Launchpad里
  • 揭开SAP Fiori编程模型规范里注解的神秘面纱 - @OData.publish工作原理解析
  • SAP Fiori里的Adapt UI按钮,神出鬼没的奥秘

本文来自云栖社区合作伙伴“汪子熙”,了解相关信息可以关注微信公众号"汪子熙"。