關於使用READ TABLE語句的幾點注意事項


原文地址   http://www.dlsap.com/thread-34-1-1.html

1.  如果使用READ TABLE語句來讀取內部表數據,而不是簡單看返回值判斷是否存在,那么在使用READ TABLE語句之前,一定要記得使用CLEAR語句清空內部表的工作區。


2.  READ TABLE itab WITH KEY = v BINARY SEARCH.

  使用READ TABLE語句的二分法搜索以 代替標准順 序搜索時, 必須首先按關鍵字中指定的次序對內表進行排序。如果系統找到匹配指定關鍵字的多行,則讀取索引最低的行。二分法搜索 比線性搜索要快。因此,應盡可能將內表排序並且使用二分法搜索。如果找到有匹配關鍵字的條目,則將系統字段 SY-SUBRC 設置為0並且 SY-TABIX 包含該行的索引。否則,將 SY-SUBRC 設置為非零。

3.  WITH KEY 中的檢索條件比較符不能使用‘<>’(不等於)。

  如果只想取得內部表中不等於某條件的一條記錄,那么請使用下面變通方法。
       LOOP AT itab WHERE KEY <> ‘XX’.
          此處取得第一條記錄。
          EXIT.
       ENDLOOP.

   如果在運行時 <KEY> 值為空,則 統忽略該關鍵字段。另外可對關鍵字段指定偏移量和長度。

BTW: 
感謝binary search,有一次到日本做項目,有這么個課題,
內部表中的數據如下
A    B    C
01  001 20060301
01  001  20060201
01  001 20060101

要求取出距現在時間最近的記錄。
我的做法是先排序
SORT IT_TAB BY A
                         B ASCENDING
                         C DESCENDING.
然后用二分法讀取
READ IT_TAB INTO WA_TAB WITH KEY A = '01'
                                                         B = '001'
                                                         BINARY SEARCH.
應該取到01  001 20060301這條記錄。(也確實取得是這條記錄)
這時來之日本SAP公司的檢證人員就挑毛病了,說你用二分法從中間切入,怎么能保證取到20060301這條,而不是20060201?
SE接到質問讓我抓圖證明用二分法沒錯,否則改用普通READ。
我聽了馬上告訴SE,ABAP語法就是這樣的,這是“常識”!
系統如果找到匹配指定關鍵字的多行,則讀取索引最低的行。
經過我的特殊排序后,20060301所在行索引最低。


免責聲明!

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



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