在項目上遇到了要同時用BAPI和BDC更新數據的情況。開發的需求如下:
ME22N中
修改采購訂單中物料條目的凈價和每,然后在物料數據頁的供應商物料號中記錄舊價格和舊每,同時在EAN/UPC中寫入'ZSJ'。
大部分的更新都可以由BAPI完成,但是EAN/UPC在BAPI中找不到對應的字段,而且客戶不願意改字段。一開始看到ME22N這種多條目的事務代碼,覺得BDC錄屏沒法做,但是其實是可以做的,只是比較麻煩。
下面一點點總結分享。
BDC部分:
BDC錄屏后,得到的結果基本是沒法直接用的,我是通過錄了很多次屏,然后東拼西湊、修修改改得出來的。
錄屏的操作流程:其他采購訂單->輸入采購訂單號->確定->項目點擊下拉列表選擇行項目->修改EAN/UPC->保存,得到的錄屏結果如下 :
直接錄屏的結果是沒法用的,必須把紅色下划線的部分去掉,保留反而會出錯。這些是錄屏的時候記錄下來的屏幕上一些字段的值,但在程序操作調用BDC的過程中,你無法知道這些字段的具體值是多少,填不對的話反而會出錯,所以要去掉。
而且在填寫BDC_FIELD的時候,帶BDC_SUBSCR的部分都可以不填寫,只要填寫一些關於操作和字段賦值的部分就可以了。
BDC調試:
BDC需要調試的話就設置模式MODE為A,這樣就可以觀看前台是怎么樣一步一步執行的,便於發現錯誤。MODE為E是只有發生錯誤才轉到前台,而MODE為N是完全的后台操作。一般先用A或E確認能執行成功后再換成N來執行。
BDC代碼:
總結下BDC的適用范圍:
BDC適用於錄制較為單一的操作,並且一般情況下不適用於多條行項目,但是也有例外。在一些特殊的事物代碼中,對於行項目的修改也能是一組比較單一的操作,比如ME22N就是每次選擇下拉列表,然后修改相應的字段。所以有時候BDC錄屏是一件需要業務顧問、技術顧問一起做、互相配合的事。
BAPI部分:
由於SAP各個表之間的關聯關系非常復雜,一個前台操作可能同時更新了N張表,所以ABAP中嚴禁直接更新標准表,這會導致不一致性。而為了保持一致性,需要更新和修改的時候則需要使用BAPI。
BAPI與BDC相比,執行速度會快些、效率會高些,而且比較適合用來更新修改多條行項目的數據。
BAPI中值得一提的是它的X參數,參數明后代X后綴的參數標示了需要更新哪些相應的字段,所以必須對X參數中需要更新的字段賦值為 X ,否則BAPI並不會更新任何字段。
X參數:
對需要更新的字段賦值:
另外ABAP中能夠支持多個BAPI連續調用,然后同時COMMIT或是ROLLBACK,以此來保證一致性。只需要再調用完BAPI后再調用BAPI_TRANSACTION_COMMIT或是BAPI_TRANSACTION_ROLLBACK。
值得一提的是BAPI_TRANSACTION_COMMIT的WAIT參數。注意:BAPI是異步更新的,所以如果不使用WAIT參數的話,那么它無法保證在執行下條語句時BAPI已經更新成功,這樣如果連續兩條語句都是寫操作,有很大可能會造成讀寫沖突,比如:我在BAPI執行完后調用BDC,如果不WAIT的話,那么就會有讀寫沖突,BAPI鎖住了一些表或是資源導致BDC無法更新。