ABAP Memory/SAP Memory/Shared Buffer/Database

ABAP提供了IMPORT/EXPORT 和 SET/GET PARAMETER語句,可對用戶內存/服務器內存/數據庫進行存儲和訪問。
不過可能很多人對此還不是很瞭解,下面我們通過實例來測試它們的區別和聯繫。

1. ABAP Memory
用戶登陸後,最多一個系統可以開6個窗口,這在SAP中稱爲External Mode。
而同一個窗口中,運行某程序後,可以通過CALL TRANSACTION/SUBMIT或其他代碼跳轉到其他程序,這個稱爲
Internal Mode。Internal Mode的調用棧最多爲9層。
那麼ABAP Memory,它是屬於Internal Mode間可以共享的數據,而External Mode間無法共享。

例子. 創建程序A,輸入:
DATA matnr TYPE matnr.
IMPORT matnr FROM MEMORY ID 'YTEST_MATNR'.
WRITE matnr.

創建程序B,輸入:
DATA matnr TYPE matnr.
matnr = '000000000000001234'.
EXPORT matnr TO MEMORY ID 'YTEST_MATNR'.
SUBMIT y_program_a. "調用程序A
直接運行B,發現程序A從ABAP Memory讀到了值並輸出到LIST.

說明:
(1)調試運行B到EXPORT語句後面,Goto-System Area-ABAP Memory,可以查看到名爲YTEST_MATNR的一片內存。
(2)如果B和A運行在不同的窗口,則A將訪問不到數據;當用戶輸入/N退出當前程序時,內存值也將被清空。
(3)該語句適用於CALL TRANSACTION/SUBMIT過程中的數據共享,也常用於User Exit,類似於定義全局變量的效果。

2. SAP Memory
上面說了External Mode,那麼它們之間共享數據必須通過SET/GET PARAMETER語句,不再是EXPORT/IMPORT的模式。

例子. 創建程序A,輸入:
DATA matnr TYPE matnr.
GET PARAMETER ID 'YTEST' FIELD matnr.
WRITE matnr.


創建程序B,輸入:

DATA: matnr TYPE matnr.
matnr = '000000000000012345'.
SET PARAMETER ID 'YTEST' FIELD matnr.
在窗口1運行程序B並關閉後,在窗口2運行程序A,發現程序A仍然讀到了SAP Memory的值。

說明:
(1)調試時,可通過Goto-System Area-SAP Memory,查看到YTEST及其對應的值。
(2)SET/GET PARAMETER的值與本次登陸有關,當用戶註銷後才失效。在用戶登陸的時候,系統會根據每個用戶
User Profile-Own Data-Parameter下的設置,載入到SAP Memory。
(3)Data Element中可以看到Further Characteristics下可定義PARAMETER ID,代表該字段作爲屏幕元素時,可
讀取該PARAMETER ID作爲默認值。比如VA03會自動顯示剛剛創建的訂單號。

3. SHARED MEMORY/SHARED BUFFER
前面介紹的都是用戶內存,那麼不同用戶間如何實現數據共享呢?可以用SHARED MEMORY或SHARED BUFFER,它們
是服務器上的某片所有用戶共享的內存。關於SHARED MEMORY和SHARED BUFFER的區別,可以F1查看幫助。如果
EXPORT SHARED BUFFER,則必須IMPORT SHARED BUFFER才能讀到,用IMPORT SHARED MEMORY是讀不到
的。反過來也是。

例子. 創建程序A,輸入: DATA matnr TYPE matnr.
IMPORT matnr FROM SHARED BUFFER indx(aa) ID 'YTEST_MATNR'.
WRITE matnr.



創建程序B,輸入:
DATA: matnr TYPE matnr.
matnr = '000000000000123456'.
EXPORT matnr TO SHARED BUFFER indx(aa) ID 'YTEST_MATNR'.
先在用戶1的電腦上運行程序B,然後在用戶2的電腦上運行程序A,發現用戶2可以讀取到值。

說明:
(1)既然是服務器上的所有用戶共享空間,那麼該值將保存到服務器關機重啓爲止,除非用戶用DELETE語句清除它。
其實這個跟ENQUEUE/DEQUEUE有點相似之處。
(2)數據庫也可共享數據,不過服務器共享肯定速度快些,理論上適合網絡遊戲,呵呵。
(3)INDX是系統中存在的符合特定格式要求的表。但這不代表該EXPORT/IMPORT語句將在表INDX中增加記錄,僅僅
代表服務器借用了INDX的結構來管理該片共享內存。

4. DATABASE
上面說了SHARED BUFFER並不訪問數據庫,而要訪問數據庫就應該用DATABASE。

創建一個程序,錄入代碼:
DATA: matnr TYPE matnr.
matnr = '000000000000004321'.
EXPORT matnr TO DATABASE indx(aa) ID 'YTEST_MATNR'.

執行程序,然後SE16查看錶INDX,發現新增了一條RELID = AA, SRTFD = YTEST_MATNR的記錄。如果EXPORT
的數據量比較大,則新增的將是多條,這些條目的字段值SRTF2從0遞增。所以EXPORT DATABASE與普通數據庫操
作的不同之處是,它適合大數據量的操作,系統自動將其拆分成多條記錄並存儲到數據庫中,比如圖片或文檔。而用
IMPORT DATABASE的過程則相反,系統將把這些條相關記錄又自動組合起來成爲一個整體。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章