Jerry的前一篇文章 揭开SAP Fiori编程模型规范里注解的神秘面纱 - @ObjectModel.readOnly工作原理解析,给大家分享了@ObjectModel.readOnly这个注解对应的Fiori UI和ABAP后台的工作原理。

今天我们继续研究另一个注解@OData.publish.

在SAP官网的ABAP Programming Model for SAP Fiori的帮助文档里,在OData Annotations目录下有对这个注解的介绍:

https://help.sap.com/viewer/cc0c305d2fab47bd808adcad3ca7ee9d/1709%20000/en-US/ccdb054e4ecf4573829d4ba258cafa72.html

一旦加上了这个注解的CDS view激活时,会自动生成一个OData服务。

这个OData服务是如何自动生成的?这就是本文所要分享的内容。

假设我们对加了这个注解的CDS view激活后自动生成的OData服务的明细一无所知,从何处开始入手进行研究呢?

我创建了一个名为zjerrytest20160311的view,然后加上这个注解,激活。根据我的经验,按照SAP惯例,自动生成的OData服务的名称应该也会包含0311这个字符串。

激活之后,我试着用0311作为关键字在OData服务的注册事务码/IWFND/MAINT_SERVICE里搜索,果然搜到了对应生成的OData服务:

在Jerry之前的文章 ABAP CCDEF, CCIMP, CCMAC, CCAU, CMXXX这些东东是什么鬼 曾经提到ABAP Netweaver的注册表TADIR,按照0311进行查询,发现CDS view激活之后,除了OData服务本身,还自动生成了下列这些对象:

IWMO: SAP Gateway Business Suite Enablement对应的模型
IWSV: SAP Gateway Business Suite Enablement对应的服务
CLAS: OData服务的实现类ZCL_ZJERRYTEST20160311

做个实验,当我把OData.publish的值设置为false,再次激活,发现类型为IWMO和IWSV的对象从注册表TADIR中消失了,这再次印证了二者是注解OData.publish设置为true之后激活CDS view生成的。

那么如何研究CDS view激活时,这两个对象的自动生成逻辑呢?

使用Jerry文章 SAP错误消息调试之七种武器:让所有的错误消息都能被定位 里介绍的第六种武器,离别钩之ST05.

打开ST05跟踪模式,激活CDS view,在数据库跟踪结果里果然发现了将自动生成的对象名称插入到注册表TADIR的OPEN SQL语句。

《神雕侠侣》天竺僧去绝情谷给杨过找情花毒解药时,说过一句话:毒蛇出没之处,七步之内必有解药。

同样,在ABAP里,在插入数据库表的OPEN SQL语句之前,必定有待插入数据的生成逻辑。

点击ST05里蓝色的眼镜图标,自动跳转到OPEN SQL语句里。设置断点,激活CDS view,断点触发:

从当前的调用栈往外追溯,发现在第21个调用栈帧,正是自动生成OData服务的地方:

CL_WB_DDLS_SECOBJ_HNDLR_SINGLE->IF_DDIC_WB_DDLS_SECOBJ_HANDLER~ON_ACTIVATION

这个方法首先根据delta_state判断出需要删除,新增或者更新的对象清单,分别存储在下图12到14行三个输出参数里。

举个例子,当我在一个已经激活过后的CDS view源代码里添加@OData.publish:true的注解,然后激活,此时该注解对于的EDIT_STATE为N(New), 而其他的注解因为没有任何变化,被标记为U(Unchanged).

此处会根据EDIT_STATE的值,进入对应的分支。

EDIT_STATE值为N的分支,则执行OData服务的创建,通过CL_SADL_GTK_ODATA_SERVICE_GEN完成,后缀GEN代表Generation.

从调试器里能看出,名称为ZJERRYTEST20160311的OData服务通过create_via_exposure方法被创建。

完整的调用栈:

本文其实也是另一个具体的例子,在不了解一段逻辑(无论框架层面或者应用层面)的情况下,如何使用ST05这个工具来找到设置断点的代码位置,从而找到问题分析的突破口。

感谢阅读。

更多阅读

  • 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里
    要获取更多Jerry的原创文章,请关注公众号"
    汪子熙":

揭开SAP Fiori编程模型规范里注解的神秘面纱 - @OData.publish工作原理解析相关推荐

  1. 揭开SAP Fiori编程模型规范里注解的神秘面纱 - @ObjectModel

    今天是农历鼠年大年初五,本文是鼠年第5篇文章,也是汪子熙公众号第204篇原创文章. 最近大家真是谈蝙蝠色变呀! SAP官网的ABAP Programming Model for Fiori帮助文档里, ...

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

    我国古代,形容一个人武艺全面,会说他/她"十八般兵器样样精通".所谓十八般兵器(有时也称十八般武艺),即刀.枪.剑.戟.斧.钺.钩.叉.鞭.锏.锤.抓.镋.棍.槊.棒.拐.流星锤. ...

  3. abap mm后台表_如何查找SAP Fiori UI上某个字段对应的底层数据库表

    今天是立春,鼠年大年十一.这是Jerry鼠年的第10篇文章,也是汪子熙公众号总共第209篇原创文章. 昨天凌晨的时候,四川地区又发生了地震. 成都市民纷纷表示,我们太难了. 2020刚一开始就活得如此 ...

  4. SAP Fiori里的Adapt UI按钮,神出鬼没的奥秘

    今天是2020年2月2日鼠年大年初九,这是Jerry鼠年的第9篇文章,也是汪子熙公众号总共第208篇原创文章. 这几天大家在家一日游的感觉如何? 工作中Jerry的同事曾经问过我一个问题,Fiori界 ...

  5. 一步步把SAP GUI的事务码配置到SAP Fiori Launchpad里

    今天是2020年1月31日鼠年大年初七,这是Jerry鼠年的第7篇文章,也是汪子熙公众号总共第206篇原创文章. Jerry之前的文章 为什么SAP GUI里的传统事务码能通过Fiori Launch ...

  6. SAP Fiori Elements 公开课第三单元学习笔记 - OData 和注解深入讲解

    课程地址 很多 SAP 从业者反映,open SAP 上的视频,因为网络原因无法访问,所以我会陆续在我的个人微 信 号"汪子熙"上面,把这些视频配上中文字幕并发布出来,敬请关注. ...

  7. SAP Fiori Elements List Report 里的表格类型(tableType)是如何决定出来的

    从 SAP Fiori Elements 实现源代码中的 SmartTable.xml 能看出,ListReport 类型的 SAP Fiori Elements 应用,其表格类型包含 4 种: An ...

  8. SAP Fiori smart template技术里CDS view的注解和UI元素对应关系

  9. SAP CAP 编程模型简介

    官网 CAP 是用于构建企业级服务和应用程序的语言.库和工具框架.它引导开发人员沿着经过验证的最佳实践和大量现成的解决方案来应对重复性任务的"黄金之路". 基于 CAP 的项目受益 ...

最新文章

  1. java实现sql批量插入参数
  2. 去中心化钱包CoinU基本介绍,你想知道的都有。
  3. mysql瓶颈分析_网站瓶颈分析—MYSQL性能分析
  4. 云小课|想实现资源全自动备份?看完这篇秘籍,不再蕉绿~
  5. Linux4版本,Linux 4.12发布,据传是历史最大版本之一
  6. (转)Locale 详解
  7. mysql注入***扫描备忘;
  8. Oracle 10.2.0.4 升级到 10.2.0.5
  9. Nginx 反向代理解决浏览器跨域问题
  10. 跟着百度学PHP[3]-PHP中结构嵌套之循环结构与条件结构嵌套
  11. 简易学生管理系统(C语言)
  12. 51单片机控制电机正反转
  13. 国内ERP技术公司综合
  14. 神经网络中常用的误差平方和损失函数是什么
  15. might和could的区别用法_could might would should区别用法
  16. HTB-SolidState
  17. bootstrap 滚动 进度条_Bootstrap中的进度条
  18. 仿照elementUI编写自己的表单组件
  19. 百行代码发射红心,程序员何愁命不中女朋友!
  20. Go语言和php个和lua,当 Go 遇上了 Lua

热门文章

  1. 终于收到为广州.NET俱乐部活动准备的礼品了:)
  2. hosts文件是什么?
  3. Mysql 数据插入 修改删除
  4. SHOI2016 黑暗前的幻想乡
  5. python基础学习(十二)变量进阶
  6. 75. Sort Colors - LeetCode
  7. 判断浏览器是否支持某个css属性
  8. css选择器的优先级
  9. Web前端岗位面试题汇总(含答案)
  10. 编译时错误之 error C2338: tuple_element index out of bounds