大象怒怒的小脚


没有终了漂泊,于是成了树上的精灵.有梦想,却不会飞翔.用自己短短的羽翼,跳跃在迷离的枝头……

首页 新随笔 联系 订阅 管理
 
DATA: BEGIN OF it_mara OCCURS 0,
        matnr LIKE mara-matnr,
        maktx LIKE makt-maktx,
      END OF it_mara.
第一种写法:
  SELECT matnr
  INTO it_mara
  FROM mara.
    APPEND it_mara.
  ENDSELECT.      
第二种写法(high performace):
  SELECT matnr
  INTO TABLE it_mara
  FROM mara.
==========================================
DATA: BEGIN OF it_mara OCCURS 0,
        matnr LIKE mara-matnr,
        maktx LIKE makt-maktx,
      END OF it_mara.
DATA: BEGIN OF it_makt OCCURS 0,
        matnr LIKE mara-matnr,
        maktx LIKE makt-maktx,
      END OF it_makt.
第一种写法:
  LOOP AT it_mara.
    SELECT SINGLE maktx
    INTO it_mara-maktx
    FROM makt
    WHERE matnr = it_mara-matnr AND
          spras = sy-langu.
    MODIFY it_mara TRANSPORTING maktx.
  ENDLOOP.      
第二种写法(high performace)  
  SELECT matnr maktx
  INTO TABLE it_makt
  FROM makt
  FOR ALL ENTRIES IN it_mara
  WHERE matnr = it_mara-matnr and
        spras = sy-langu.

=================================================================================
1 数据——>工作区,工作区——>内表,
2 数据——>内表
很明显少了一个过程 效率自然高了 如果数据量越大,效果是可想而知的
=========================================
1 每遍历内表一下 都要select一下 select 本身就是循环
循环循环 时间消耗度是n*n
2select出已经存在内表中的所有满足条件的值 不敢说时间消耗度是n*n 但至少时间上大大地打了一下折

posted on 2005-11-03 13:24  大象怒怒  阅读(463)  评论(0编辑  收藏  举报