提高BSEG處理效率

來源:互聯網
上載者:User
BSEG於一般的透明表不同,它是一個簇表。對於一個簇表來說,除了主鍵項目外,其他項目都被編輯到一個長文本項目中,一起儲存在表簇RFBLG中的vardata項目中,這就決定了作為簇表的BSEG無法再建立索引值以外的索引(INDEX),所以一般我們對於透明表來說當主鍵項目不全或完全沒有時,追加索引的作法對於BSEG表來說就不好用了。而BSEG簇表又是SAP系統中FI 會計模組中最常被使用的資料表,所以運用好對BSEG表的訪問技術對於FI會計模組的擴充開發(ADDON)至關重要。

這篇文章我們就來談談如何高效地對BSEG進行訪問處理。

對於簇表來說,在資料庫中沒有與之同名的實體物理表相對應,所以雖然其可在ABAP中使用,但還是有一些限制的:
1. 不能使用Select distinct文法
BSEG中的欄位儲存在VARDATA中,所以不能使用distinct語句對單個項目去除重複。
2. 不能使用Native SQL
在資料庫中沒有與之同名的實體物理表相對應,所以不能使用Native SQL 對BSEG操作。
3. 不能使用Order by 文法
BSEG中的欄位儲存在VARDATA中,所以不能使用Order by語句對單個項目排序。
4. 不能再追加建立索引
BSEG中的欄位儲存在VARDATA中,所以不能再追加建立索引。

除此之外,對BSEG的訪問要使用主鍵項目,如果沒有主鍵項目雖然文法調試能夠通過,但是程式執行起來,耗時間長度,效率低,而且隨著業務量的增加執行時間問題會越發嚴重,甚至導致程式不能正常執行結束。

那麼如果當索引值不足時怎麼辦呢?回答,使用二次索引透明表,具體方法如下描述。

比如和銷售憑證有關的業務,根據銷售憑證編號和明細編號,選取相關會計憑證明細資訊。
SELECT *
FROM BSEG
WHERE VBEL2 = 'XXXXXXXXXX'     “ 銷售憑證編號
AND POSN2 = 'YYYYYY'.      “ 銷售憑證明細編號
在這個例子中,對BSEG的檢索條件中因為沒有主鍵項目,所以執行起來,程式很慢。

變通的方法:
1)首先根據銷售憑證編號和明細編號,從BSID中檢索出未清帳明細行項目。
SELECT BURKS “ 公司代碼
BELNR “ 財務憑證編號
GJAHR “ 會計年度
BUZEL “ 會計憑證中的行項目
FROM BSID
INTO TABLE TAB_KEY “ 存放主鍵項目的內部表
WHERE VBEL2 = 'XXXXXXXXXX' “ 銷售憑證編號
AND POSN2 = 'YYYYYY'. “ 銷售憑證明細編號

2)再根據銷售憑證編號和明細編號,從BSAD中檢索出已清帳明細行項目。
SELECT BURKS “ 公司代碼
BELNR “ 財務憑證編號
GJAHR “ 會計年度
BUZEL “ 會計憑證中的行項目
FROM BSAD
APPEND TABLE TAB_KEY “ 存放主鍵項目的內部表
WHERE VBEL2 = 'XXXXXXXXXX' “ 銷售憑證編號
AND POSN2 = 'YYYYYY'. “ 銷售憑證明細編號

3)然後再根據上面檢索出的主鍵列表,從BSEG中檢索出相應的明細行項目。
SELECT BSCHL "転記キー
KOART "勘定タイプ
UMSKZ "特殊仕訳コ
SHKZG "借方/貸方
HKONT "総勘定元帳
GSBER "事業領域
DMBTR "國內通貨額
WRBTR "伝票通貨額
ZUONR "ソートキー
SGTXT "明細テキス
ZFBDT "期日計算の
ZTERM "支払條件キ
ZLSCH "支払方法
ZLSPR "支払保留キ
HBKID "取引銀行の
BVTYP "取引先銀行
FROM BSEG
INTO TABLE TAB_BSEG “ 存放檢索結果的內部表
FOR ALL ENTRIES IN TAB_KEY “ 存放主鍵項目的內部表
WHERE BUKRS = TAB_KEY-BUKRS. “ 公司代碼
AND GJAHR = TAB_KEY-GJAHR “ 財務憑證編號
AND BELNR = TAB_KEY-BELNR “ 會計年度
AND BUZEI = TAB_KEY-BUZEI. “ 會計憑證中的行項目

4)這麼處理之所以能夠提高效率,關鍵還得對透明表BSID和BSAD追加以VBEL2(銷售憑證編號)和POSN2(銷售憑證明細編號)為索引值的索引(對於透明表可追加索引)。

這樣一來,1)和2)步驟地操作有索引,3)步驟的操作有全主鍵項目,檢索速度應該有保證。

採購方面的業務、物料方面的業務等都可如法炮製。

最後需要說明一點,不是所有的SAP體統都可以使用這種方法,能否使用取決於R/3系統的設計和配置。所以在試圖使用該方法時應充分調查相關透明表與BSEG中的紀錄是否相符,別速度提高了,結果處理物件範圍減小了或增大了,那就與初衷背道而馳了,效率的提升一定要在確保業務資料正確的基礎上再加以考慮。

SAP R/3系統中也有幾個專門用來讀取BSEG表資訊的函數,可適當參考使用,它們是:
READ_BSEG
GET_ALL_BSEG

另外最有效率的方法是改善你的應用和需求,要使需求合理規範,這才能使效率達到最高化。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.