激活鎖定對象時,產生的 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. 四、上鎖的一般步驟 先上鎖,上鎖成功之后,從數據庫取數據,然后更改數據,接着更新到數據庫,最后解鎖。按照這個步驟,才能保證更改完全運行在鎖的保護機制下。