SAP程序變式和選擇變量(轉)


原文鏈接:https://www.jianshu.com/p/e8718bb91bc0

前言

說起SAP中的變式(Variant),SAP從業者肯定不會陌生,對於選擇屏幕復雜的程序界面,我們可以使用變式來簡化界面(比如隱藏不相關字段),對於經常使用的並且每次都需要輸入相同篩選條件的程序(比如每月都要執行的報表),可以設定和調用變式來簡化操作,此外當我們需要需要設定后台JOB時,我們也需要為后台程序指定相應的變式。

本文嘗試為變式相關概念做些總結,並再簡單說下變式中的選擇變量(Selection variables)的用法。

維護變式

當我們新定義一個變式時,有兩種:

       1.進入選擇界面,在選擇屏幕輸入選擇條件,點擊保存按鈕進入變式屬性界面,填上變式名字和描述,保存

       2.通過SE38,填上程序名,選擇子對象變式,點擊顯示或修改按鈕進入變式維護界面。

 當我們需要從前台調用時變式時,只要點擊變式按鈕雙擊想調用的變式即可。

 ***當一個程序的變式數大於10個時,點擊變式按鈕會彈出額外的選擇界面:

變式屬性

使用屏幕分配 (Use screen assignment)

如果一個程序包含多個選擇屏幕(例如:COOIS),當我們只想編輯某一個選擇屏幕的變式屬性時,可以先在右側勾選選擇屏幕號,然后再點擊使用屏幕分配按鈕,這時下方的窗格就會只顯示對應的選擇屏幕字段,當然SAP中大多數程序還是只有一個選擇屏幕界面,所以這個按鈕用到的情況並不多。

僅用於后台處理 (Only for Background Processing)

如果勾上了此項,那么變式就不能在前台被調用了,只能用於后台JOB。

保護變式 (Protect Variant)

勾選后,該變式其他用戶無法修改。

僅在目錄中顯示 (Only Display in Catalog)

勾選后,點擊變式按鈕不會看見此變式,變式也不會出現在SE38的變式子界面的搜索幫助中,只能在變式目錄中找到此變式。


變式目錄可以在SE38的變式子界面,通過如下菜單位置找到:

 

 僅出現在變式目錄中的變式依然可以被用於定義后台JOB:

系統變式 (System Variant)

該選項無法手工勾選,當定義新的系統變式或查看系統變式時會自動勾上。

關於系統變式可以分享的幾點如下:

A. 系統變式命名以SAP&或CUS&開頭,SAP&表示SAP原生定義的系統變式,CUS&表示客戶自定義的系統變式

B. 無法為本地程序定義系統變式,否則系統會給出DB248報錯  

 

 



 

 

 

 

 

 

 

 

C. 系統變式不會被覆蓋並且只能由創建者或最后修改者修改

D. 系統變式保存時會觸發自動傳輸(Workbench類型,傳輸對象是 LIMU VARI)

E. 當傳輸程序時,對應的系統變式會一起被傳輸

F. 系統變式不區分Client (not client-specific),系統變式只能從Client 000中調用T類型選擇變量(靜態變量),這個下面會談到。

屏幕字段類型 (Type)

屏幕字段一共有兩種類型,P和S , P表示參數(PARAMETERS),S表示選擇選項(SELECTION-OPTIONS),從前台界面上來看就會一下子明白。(這里需要說明的是,並不是屏幕上看到單個空格的就一定是P類型,用SELECTION-OPTIONS定義的選擇屏幕也是可以實現單個空格效果的)。

不同類型的屏幕字段也只能調用相應類型的選擇變量,這個下面會談到。

 

 

保護字段 (Protect field)

勾選后,當程序調用此變式執行時,字段在前台選擇屏幕上可見,但不接受用戶輸入,只能在維護變式時錄入。

隱藏字段 (Hide field / Hide field 'TO')

勾選后,當程序調用此變式執行時,字段在前台選擇屏幕上將不可見,但在維護變式時錄入的值依然有效。

保存無值的字段 (Save field without values)

使用后,系統在保存變式時會不考慮錄入的字段值。

如果該字段與MEMORY ID無關,那么對該字段系統將以空值保存在變式中。

如果該字段與MEMORY ID有關,那么系統在調用變式時該字段值會受到SAP memory中的值和用戶變量的影響,具體三者間的關系,后面會談到。關於MEMORY ID下面也會聊到。

GPA關閉 (Switch GPA off)

這里的GPA指的是SPA/GPA, 即SELECT/GET Parameter ID,也就是用戶參數文件中的SET/GET 參數標識(可以用SU3或SU01維護),Parameter ID(pid)存在表TPARA中。

 

 

要討論這個選項,我們需要先說下SAP memory。我們在日常操作中肯定注意過這種現象,就是有時我們進入到一些程序時(注意:不是用變式啟動),會發現有些字段的值已經自動填寫上了,這里其實用到了SAP memory機制。在這種機制下,當一個屏幕被調用時,那些用MEMORY ID語法定義的屏幕字段會去SAP memory中搜尋當前值,並自動填充到屏幕上。SAP memory是與用戶ID綁定的,這種機制提高了用戶的操作體驗。

下面我們先看一個例子,理解下這個自動填充的邏輯:

登錄SAP, 我們在SU3中維護PID WRK = 8000

進入MB51, 會發現工廠字段是自動填寫上8000的

我們手工改為6000 (注意:要按下回車才會進入SAP memory),退出MB51

再次進入MB51,會發現工廠字段默認帶出了6000 (其實進入MB52也會發現工廠字段自動會帶出6000)

我們手工改為空,退出MB51

再次進入MB51,會發現工廠字段默認為空

登出SAP,再次登錄SAP,進入MB51,會發現工廠字段自動帶出了8000

退出MB51,進入SU3修改WRK = 6010

再次進入MB51,會發現工廠字段默認帶出了6010

這里我們就可以明白這個SAP memory的工作原理了,當我們以無變式方式進入一個程序屏幕時,假如A字段用到了MEMORY ID語句關聯了PID,並且沒有在語法中給出默認值,那么當SAP memory中有值時系統會優先調用(注意:包括其他屏幕操作寫入的值、空值和新保存在用戶參數文件中的值),當SAP memory中還沒有值時(比如剛登錄系統,未進行其他操作),系統會去檢查用戶參數文件中有無維護PID,如果有,就調用PID值(包括空值),如果沒有,那么就以初始值顯示(即空值)。

回到GPA關閉這個選項上來,首先這個選項只對使用了MEMORY ID定義的屏幕字段有效,對其他屏幕字段來說這個選項是不可編輯的。如果我們勾選了GPA關閉,那么當我們調用變式時,就不會觸發SAP memory機制。

更詳細的舉例可以參加后面的組合測試部分。

 

 

 

 

要求的字段 (Required field)

使用后,當程序調用此變式執行時,該字段在選擇屏幕上變為必輸項。

選擇變量 (Selection variable)

選擇變量可以幫助我們更靈活去管理變式,目前SAP支持的選擇變量一共有4種:

靜態變量,即表TVARVC中的值 (類型T)

動態日期計算 (類型D、X)

動態時間計算 (類型Z、Y)

用戶變量 (類型B)

下面我們依次來看下這幾種變量的用法。

T類型選擇變量:表TVARVC中的值

我們可以直接將表TVARVC中定義的值用在變式中,這樣當選擇條件發生小的變更時,就不用每次都去變更已有的變式,只要更新表TVARVC中的靜態變量即可。

T類型選擇變量也可以配合保護字段一起使用。

假如我們每月需要為所有的工廠執行一系列的報表或程序,我們為這些程序創建了變式,並設定了后台JOB,隨着業務的增長,每當有新的工廠被創建后,我們需要為這一系列程序去修改變式。如果我們在表TVARVC中定義了一個ZPLANT的變量(類型:選擇選項),並將這個變量應用在所有的變式中,這樣當業務環境發生變化時,我們就僅需要去修改ZPLANT這個變量值,這將大大簡化我們的工作量。

關於T類型的選擇變量,其他需要說明的有:

A. T類型選擇變量存儲在表TVARV和TVARVC中,TVARV不區分Client,TVARVC區分Client

B. 自Release 610開始, TVARV 被TVARVC所替代,可以用程序RSTVARVCLIENTDEPENDENT來將 TVARV的值拷貝至TVARVC

C. 事務碼STVARV可以用來維護當前Client的表TVARVC中的值,事務碼STVARVC可以在任一Client維護Client 000的表TVARVC的值。也可以在變式屬性定義界面通過菜單>環境>定義選擇變量進行維護。

D. Client 000中的表TVARVC中的值是給系統變式用的。

E. P類型的屏幕字段可以調用表TVARVC中的參數值,S類型的屏幕字段可以調用表TVARVC中的選擇選項值

F. 因為動態期間計算不能涵蓋所有場景,我們可以根據需要在表TVARVC創建變量,並開發一個程序進行定期更新。

比如事務碼IDCNACCTBLN中的年份和期間這兩個字段不能使用動態計算,我們可以在表TVARVC創建變量ZCURRENT_YEAR(本年)和ZLAST_PERIOD(上月),通過一個自開發程序每月去更新ZCURRENT_PERIOD,每年去更新ZCURRENT_YEAR。

注意:T類型的選擇變量會影響到所有調用它的變式

D、X類型選擇變量:動態日期計算

 

 只有數據類型為DATS的屏幕字段才能使用動態日期計算。D類型動態日期計算使用的是本地日期,X類型使用的是系統日期。

 

 SAP支持的動態日期計算選擇如下:

 

 Z、Y類型選擇變量:動態時間計算

 

 只有數據類型為TIMS的的屏幕字段才能使用動態時間計算。Z類型動態日期計算使用的是本地時間,Y類型使用的是系統時間。

 

 SAP支持的動態時間計算選擇如下:

 

 B類型選擇變量:用戶變量 (User-specific Selection Variables)

最后來看下用戶變量,用戶變量是與用戶ID綁定的選擇變量,如果我們要在變式中使用用戶變量,需要滿足3個條件:

No.1 該屏幕字段用到了MEMORY ID語法關聯到了PID;

No.2 表TUVID 中有相應的PID值;

No.3 已經維護了相應的用戶變量值 (用戶變量存儲在表TVARUVN中)。

當以上條件達到時,我們在維護變式時就可以選擇類型B作為選擇變量,並且系統會自動帶出變量名稱。

維護用戶變量

維護用戶變量的方法有兩種:

一. 通過菜單

A. 在選擇屏幕中,通過菜單>轉到>用戶變量進入維護界面

 

 B. 單擊要維護的PID

C. 眼鏡按鈕會顯示當前的用戶參數值,筆按鈕會進入修改界面,如果點擊獲取,會讀取當前的用戶參數值並填到屏幕字段上

D. 點擊筆后,選擇變量,填上參數值保存即可。(注意:需要點擊刪除才會保存成功,如果選擇保存空,就會以空值保存

E. 點擊筆后,如果點擊選擇屏幕,系統會讀取當前屏幕上的值做出輸入參照

F. 如果要刪除用戶變量值,需要進入修改界面然后將參數值改為空,最后選擇刪除即可

 

 

 

 

 

 

二. 調用功能

用戶變量也可以通過SE37調用功能來修改,相關的功能如下:

VARI_USER_VARS_GET: 讀取現有變量值

VARI_USER_VARS_SET: 修改現有變量值

VARI_USER_VARS_COPY:復制變量值

VARI_USER_VARS_DELETE:刪除變量值

VARI_USER_VARS_RENAME:重命名變量值

VARI_USER_VARS_DIALOG:出現對話框輸入變量值

組合測試

我們可以看到用戶變量和SAP memory都關聯到了PID,那么它們間的關系又是怎樣的呢?我自己花了點時間測試了下保存無值字段,GPA關閉及用戶變量這幾個易混淆的選項,在此也把測試的結果分享給大家,希望大家看過后可以了然於胸。

測試對象:

 測試場景:

 測試結果:


從上面可以看出,如果不考慮保存無值字段的影響,系統取值時優先級最高的是用戶變量,然后是創建變式時手工錄入的字段值,最后是GPA(SAP memory)

文件鏈接:

鏈接:https://pan.baidu.com/s/1t9Iqbeb4agVgp3WOTtCxDg 
提取碼:ttnr



原文鏈接:https://www.jianshu.com/p/e8718bb91bc0


免責聲明!

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



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