真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

OData服務(wù)是如何自動生成的-創(chuàng)新互聯(lián)

本篇內(nèi)容主要講解“OData服務(wù)是如何自動生成的”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“OData服務(wù)是如何自動生成的”吧!

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:空間域名、網(wǎng)站空間、營銷軟件、網(wǎng)站建設(shè)、北辰網(wǎng)站維護、網(wǎng)站推廣。

假設(shè)我們對加了這個注解的CDS view激活后自動生成的OData服務(wù)的明細一無所知,從何處開始入手進行研究呢?

我創(chuàng)建了一個名為zjerrytest20160311的view,然后加上這個注解,激活。根據(jù)我的經(jīng)驗,按照SAP慣例,自動生成的OData服務(wù)的名稱應(yīng)該也會包含0311這個字符串。

OData服務(wù)是如何自動生成的

激活之后,我試著用0311作為關(guān)鍵字在OData服務(wù)的注冊事務(wù)碼/IWFND/MAINT_SERVICE里搜索,果然搜到了對應(yīng)生成的OData服務(wù):

OData服務(wù)是如何自動生成的

在Jerry之前的文章 [ABAP CCDEF, CCIMP, CCMAC, CCAU, CMXXX這些東東是什么鬼]( ABAP CCDEF, CCIMP, CCMAC, CCAU, CMXXX這些東東是什么鬼) 曾經(jīng)提到ABAP Netweaver的注冊表TADIR,按照0311進行查詢,發(fā)現(xiàn)CDS view激活之后,除了OData服務(wù)本身,還自動生成了下列這些對象:

OData服務(wù)是如何自動生成的

  • IWMO: SAP Gateway Business Suite Enablement對應(yīng)的模型

  • IWSV: SAP Gateway Business Suite Enablement對應(yīng)的服務(wù)

  • CLAS: OData服務(wù)的實現(xiàn)類ZCL_ZJERRYTEST20160311

做個實驗,當(dāng)我把OData.publish的值設(shè)置為false,再次激活,發(fā)現(xiàn)類型為IWMO和IWSV的對象從注冊表TADIR中消失了,這再次印證了二者是注解OData.publish設(shè)置為true之后激活CDS view生成的。

OData服務(wù)是如何自動生成的

那么如何研究CDS view激活時,這兩個對象的自動生成邏輯呢?

使用Jerry文章( SAP錯誤消息調(diào)試之七種武器:讓所有的錯誤消息都能被定位) 里介紹的第六種武器,離別鉤之ST05.

打開ST05跟蹤模式,激活CDS view,在數(shù)據(jù)庫跟蹤結(jié)果里果然發(fā)現(xiàn)了將自動生成的對象名稱插入到注冊表TADIR的OPEN SQL語句。

OData服務(wù)是如何自動生成的

《神雕俠侶》天竺僧去絕情谷給楊過找情花毒解藥時,說過一句話:毒蛇出沒之處,七步之內(nèi)必有解藥。

OData服務(wù)是如何自動生成的

同樣,在ABAP里,在插入數(shù)據(jù)庫表的OPEN SQL語句之前,必定有待插入數(shù)據(jù)的生成邏輯。

點擊ST05里藍色的眼鏡圖標(biāo),自動跳轉(zhuǎn)到OPEN SQL語句里。設(shè)置斷點,激活CDS view,斷點觸發(fā):

OData服務(wù)是如何自動生成的

從當(dāng)前的調(diào)用棧往外追溯,發(fā)現(xiàn)在第21個調(diào)用棧幀,正是自動生成OData服務(wù)的地方:

OData服務(wù)是如何自動生成的

CL_WB_DDLS_SECOBJ_HNDLR_SINGLE->IF_DDIC_WB_DDLS_SECOBJ_HANDLER~ON_ACTIVATION

這個方法首先根據(jù)delta_state判斷出需要刪除,新增或者更新的對象清單,分別存儲在下圖12到14行三個輸出參數(shù)里。

OData服務(wù)是如何自動生成的

舉個例子,當(dāng)我在一個已經(jīng)激活過后的CDS view源代碼里添加@OData.publish:true的注解,然后激活,此時該注解對于的EDIT_STATE為N(New), 而其他的注解因為沒有任何變化,被標(biāo)記為U(Unchanged).

OData服務(wù)是如何自動生成的

此處會根據(jù)EDIT_STATE的值,進入對應(yīng)的分支。

OData服務(wù)是如何自動生成的

EDIT_STATE值為N的分支,則執(zhí)行OData服務(wù)的創(chuàng)建,通過CL_SADL_GTK_ODATA_SERVICE_GEN完成,后綴GEN代表Generation.

OData服務(wù)是如何自動生成的

從調(diào)試器里能看出,名稱為ZJERRYTEST20160311的OData服務(wù)通過create_via_exposure方法被創(chuàng)建。

完整的調(diào)用棧:

OData服務(wù)是如何自動生成的

到此,相信大家對“OData服務(wù)是如何自動生成的”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!


分享名稱:OData服務(wù)是如何自動生成的-創(chuàng)新互聯(lián)
文章網(wǎng)址:http://weahome.cn/article/ddgjco.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部