轉貼
http://spaces.msn.com/kongxiangshuai/PersonalSpace.aspx?_c11_blogpart_blogpart=blogview&_c=blogpart&partqs=amonth%3d4%26ayear%3d2006

 

ABAP築基寶典(5)--關於使用READ TABLE語句的幾點注意事項

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.

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

 

 

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所在行索引最低。

過後他調查了一下,一點脾氣都沒有,乖乖地說OK,呵呵。

arrow
arrow
    全站熱搜

    ROACH 發表在 痞客邦 留言(0) 人氣()