天天看點

ABAP中的系統變量SY-INDEX與SY-TABIX

  系統變量SY-INDEX與SY-TABIX是用來記錄循環的次數或者索引的,不同的是SY-INDEX在DO....ENDDO中是有效的,而SY-TABIX在LOOP....ENDLOOP中及READ内表時擷取相應的索引。

  DATA:BEGIN OF STUDENT OCCURS 0,

         NAME(10) TYPE C,

         AGE TYPE I,

       END OF STUDENT.

  DATA DENT LIKE LINE OF STUDENT.

  STUDENT-NAME = 'JACK'.

  STUDENT-AGE = 20.

  APPEND STUDENT.

  STUDENT-NAME = 'JIM'.

  STUDENT-AGE = 25.

  STUDENT-NAME = 'TOMMY'.

  STUDENT-AGE = 28.

  STUDENT-NAME = 'BUSHI'.

  STUDENT-NAME = 'LILY'.

  STUDENT-AGE = 26.

  STUDENT-NAME = 'ALEX'.

  WRITE: '1.LOOP循環'.

  WRITE: / '-----------------------------------------------'.

  LOOP AT STUDENT.

    WRITE: / 'SY-INDEX=',SY-INDEX LEFT-JUSTIFIED, "LEFT-JUSTIFIED  輸出向左對齊

             'SY-TABIX=',SY-TABIX LEFT-JUSTIFIED,

             'NAME=',STUDENT-NAME LEFT-JUSTIFIED,

             'AGE=',STUDENT-AGE LEFT-JUSTIFIED.

  ENDLOOP.

  WRITE: / '2.READ INTERNAL TABLE'.

  READ TABLE STUDENT INTO DENT WITH KEY NAME = 'ALEX'. "按具體字段值讀取内表

  WRITE: / 'SY-INDEX=',SY-INDEX LEFT-JUSTIFIED,

           'SY-TABIX=',SY-TABIX LEFT-JUSTIFIED, "讀取内表時,傳回相應資料在内表中的索引

           'NAME=',DENT-NAME LEFT-JUSTIFIED,

           'AGE=',DENT-AGE LEFT-JUSTIFIED.

  READ TABLE STUDENT INTO DENT WITH KEY NAME = 'BUSHI'. "按具體字段值讀取内表

           'SY-TABIX=',SY-TABIX LEFT-JUSTIFIED,

           'NAME=',DENT-NAME LEFT-JUSTIFIED,

           'AGE=',DENT-AGE LEFT-JUSTIFIED.

  CLEAR SY-TABIX.

  WRITE: / '3.DO...ENDDO'.

  DO 5 TIMES.

    WRITE:/ 'SY-INDEX=',SY-INDEX LEFT-JUSTIFIED,

            'SY-TABIX=',SY-TABIX LEFT-JUSTIFIED.

  ENDDO.

  

  從上面的測試例子中,我們不難看出結果。嘎嘎。。

繼續閱讀