揭开SAP Fiori编程模型规范里注解的神秘面纱 - @OData.publish工作原理解析
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工作原理解析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 什么是ABAP的STATE_READ_A
- 下一篇: 如何用flash制作数字百分比加载中进度