ABAP 鎖對象與加鎖機制


激活鎖定對象時,產生的 FM 的名字是什么?

答案:首先要在 ABAP 字典中創建鎖對象,然后才能在 ABAP 程序中設鎖。創建鎖對象時,系統會自動生成兩個 FM 來進行鎖管理。用於設鎖的 FM 為: ENQUEUE_<鎖對象名>。它用於在鎖表(Lock Table)中生成一個鎖項(Lock Entry)。若設鎖不成功的話,就會在 Return 中反映出來。用於釋放鎖的 FM 為:DEQUEUE_<鎖對象名>。它用於從鎖表中刪除一個鎖項。在 ABAP 程序中,只需使用 "CALL FUNCITION ..." 語句就可以調用它們。這兩個鎖 FM 是在 SAP 系統的一個特殊工作進程中執行的,專門進行鎖管理。它運行在一個單獨的服務器上,而該服務器專門用於維護整個 SAP 系統的主鎖表(Central Locak Table)。

有兩種鎖類型:共享鎖——只讀鎖,一個用戶正在讀數據時,阻止其他用戶更改該數據。

                  獨占鎖——可寫鎖,一個用戶正在修改數據時,阻止其他用戶更改該數據。

 

SAP鎖機制 一、SAP為什么要設置鎖:    1,保持數據的一致性      如果幾個用戶要訪問同樣的資源,需要找到一種同步訪問的方法去保持數據的一致性。比如說,在航班預訂系統中,需要檢查還有沒有空座位,當檢查的時候,你不想別人修改重要的數據(空座位的數量)。    2,僅僅用Database鎖是不夠的      數據庫管理系統物理鎖定了要修改的行記錄,其他用戶要等到數據庫鎖釋放才能訪問這個記錄。      在SAP系統中,當一個新屏幕顯示的時候會釋放掉Database鎖,因為屏幕的改變會觸發一個隱式的DB COMMIT。如果數據是從好幾個屏幕收集來的話,而且在這段時間內這些數據會分別被鎖定,僅僅用Database鎖就不夠了。      SAP系統在應用服務器層面有一個全局的LOCK TABLE,可以用來設置邏輯鎖來鎖定相關的表條目,並有ENQUEUE工作進程來管理這些鎖。SAP鎖是一種邏輯意義上的鎖,有可能你鎖定的表條目在DATABASE上根本就不存在。


二、鎖對象和其對應的Function Module    

在SE11里創建鎖對象,自定義的鎖對象都必須以EZ或者EY開頭來命名。一個鎖對象里只包含一個PRIMARY TABLE,可以包含若干個SECONDARY TABLE,鎖的模式有三種:E,S,X。LOCK PARAMETERS里填寫你要根據哪些字段來鎖定表條目。    

模式E:當更改數據的時候設置為此模式。    

模式S:本身不需要更改數據,但是希望顯示的數據不被別人更改。    

模式X:和E類似,但是不允許累加,完全獨占。    

如果你在一個程序里成功對一個鎖對象加鎖之后,如果模式為E,其他用戶不能再對這個鎖對象加E、X、S模式的任意一種鎖;    

如果你在一個程序里成功對一個鎖對象加鎖之后,如果模式為X,其他用戶不能再對這個鎖對象加E、X、S模式的任意一種鎖;  

   如果你在一個程序里成功對一個鎖對象加鎖之后,

如果模式為S,其他用戶不能再對這個鎖對象加E、X模式的鎖,但是可以加S模式的鎖;  

   如果你在一個程序里成功對一個鎖對象加鎖之后,如果模式為E,在這個程序,你還可以再對這個鎖對象加E、S模式的鎖,X模式的不可以。  

   如果你在一個程序里成功對一個鎖對象加鎖之后,如果模式為X,在這個程序,你不可以再對這個鎖對象加E、X、S模式的鎖。  

   如果你在一個程序里成功對一個鎖對象加鎖之后,如果模式為S,在這個程序,你還可以再對這個鎖對象加S模式的鎖,

如果沒有別的用戶對其加S模式的鎖,那么你還可以對其加E模式的鎖。X模式的不可以。    

當激活鎖對象的時候,系統會自動創建兩個FM,ENQUEUE_<鎖對象名>和DEQUEUE_<鎖對象名>,分別用來鎖定和解鎖。


三、鎖定和解鎖     當用邏輯鎖來鎖定表條目的時候,系統會自動向LOCK TABLE中寫入記錄。 當調用設置鎖的FM時,LOCK PARAMETERS如果沒有指明,系統會鎖定整個表。當然,LOCK PARAMETER:

CLIENT有點特殊,如果不指定,默認是SY-MANDT;如果指定相應的CLIENT,會鎖定對應CLIENT上的相應的表記錄;如果設置為SPACE,則鎖定涉及所有的CLIENT。     當邏輯鎖設置失敗后,一般會有兩種例外。一個是EXCEPTION:FOREIGN_LOCK,意思是已經被鎖定了;另一個是EXCEPTION:SYSTEM_FAILURE。    

有些情況下,程序中設置成功的邏輯鎖會隱式的自己解鎖。比如說程序結束發生的時候(MESSAGE TYPE為A或者X的時候),使用語句LEAVE PROGRAM,LEAVE TO TRANSACTION,或者在命令行輸入/n回車以后。    

在程序的結束可以用DEQUEUE FUNCTION MODULE來解鎖(當然如果你不寫這個,程序結束的時候也會自動的解鎖),這個時候,系統會自動從LOCK TABLE把相應的記錄刪除。使用DEQUEUE FUNCTION MODULE來解鎖的時候,不會產生EXCEPTION。要解開你在程序中創建的所有的邏輯鎖,可以用FM:DEQUEUE_ALL.    四、上鎖的一般步驟     先上鎖,上鎖成功之后,從數據庫取數據,然后更改數據,接着更新到數據庫,最后解鎖。按照這個步驟,才能保證更改完全運行在鎖的保護機制下。

 
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM