메뉴 건너뛰기

SAP 한국 커뮤니티

BAPI_PO_CHANGE

노름마치 2009.09.03 22:16 조회 수 : 8139

 

TABLES : ekko,ekpo,marc.

DATA : BEGIN OF itab OCCURS 0,
       aedat TYPE erdat,
       lifnr TYPE lifnr,
       emlif TYPE emlif,
       ebeln TYPE ebeln,
       ebelp TYPE ebelp,
       menge TYPE menge_d,  "po qty
       wemng TYPE menge_d,  "gr qty
       END OF itab.
DATA : stab  LIKE itab.

DATA : gv_purchaseorder LIKE ekko-ebeln.   "Purchase order
DATA : gs_poheader   LIKE bapimepoheader,  "Header Data
       gs_poheaderx  LIKE bapimepoheaderx, "Header Data(Change Toolbar)
       gt_poitem     LIKE bapimepoitem  OCCURS 0 WITH HEADER LINE,
       gt_poitemx    LIKE bapimepoitemx OCCURS 0 WITH HEADER LINE,
       gt_return     LIKE bapiret2      OCCURS 0 WITH HEADER LINE,
       gs_expheader  LIKE bapimepoheader.   "Header Data(Return)

CLEAR itab[].
SELECT ekko~aedat  AS aedat
       ekko~lifnr  AS lifnr
       ekpo~emlif  AS emlif
       ekpo~ebeln  AS ebeln
       ekpo~ebelp  AS ebelp
       eket~menge  AS menge
       eket~wemng  AS wemng
       INTO CORRESPONDING FIELDS OF TABLE itab
       FROM ekko
       INNER JOIN ekpo
               ON ekko~ebeln = ekpo~ebeln
       INNER JOIN eket
               ON ekpo~ebeln = eket~ebeln
              AND ekpo~ebelp = eket~ebelp
       WHERE ekko~bstyp = 'F'
       AND   ekko~loekz = ''
       AND   ekpo~loekz = ''
       AND   ekpo~elikz = ''
       AND   ekpo~lblkz = 'X'
       AND   ekko~lifnr = '001000772'
       AND   ekpo~werks = '1000'
       AND   eket~wemng = 0
       AND   ekko~lifnr = ( SELECT po~emlif
                                   FROM ekpo AS po
                                   WHERE po~ebeln = ekpo~ebeln
                                   AND   po~ebelp = ekpo~ebelp ).

IF itab[] IS INITIAL.
  MESSAGE s899(mm) WITH 'no data found'.
  LEAVE LIST-PROCESSING.
ENDIF.

SORT itab BY aedat lifnr ebeln ebelp.

LOOP AT itab.
  MOVE-CORRESPONDING itab TO stab.
  AT NEW ebeln.
    CLEAR : gv_purchaseorder, gs_poheader, gs_poheaderx.
    gv_purchaseorder       = stab-ebeln.
    gs_poheader-po_number  = stab-ebeln.
    gs_poheaderx-po_number = 'X'.
  ENDAT.

  gt_poitem-po_item     = stab-ebelp.
  gt_poitem-delete_ind  = 'L'.
  APPEND gt_poitem.

  gt_poitemx-po_item    = stab-ebelp.
  gt_poitemx-po_itemx   = 'X'.
  gt_poitemx-delete_ind = 'X'.
  APPEND gt_poitemx.

  AT END OF ebeln.
    CALL FUNCTION 'BAPI_PO_CHANGE'
      EXPORTING
        purchaseorder = gv_purchaseorder
        poheader      = gs_poheader
        poheaderx     = gs_poheaderx
      IMPORTING
        expheader     = gs_expheader
      TABLES
        return        = gt_return
        poitem        = gt_poitem
        poitemx       = gt_poitemx.

    READ TABLE gt_return WITH KEY type = 'S' number = '023'.
    IF sy-subrc IS INITIAL.
      CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
        EXPORTING
          wait = 'X'.
    ELSE.
      CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'.
    ENDIF.

    CLEAR : gv_purchaseorder,
            gs_expheader,
            gs_poheader,
            gs_poheaderx,
            gt_poitem[],
            gt_poitemx[],
            gt_return[].
  ENDAT.
ENDLOOP.
번호 제목 글쓴이 날짜 조회 수
327 R3 System과 타 System과의 연동 [1] 열공아밥 2009.12.20 4601
326 abap 전반적인 한글번역 [14] 열공아밥 2009.12.20 7410
325 New abap 디버거기능소개 [3] 열공아밥 2009.12.20 5880
324 로그온 후 exit, logon, login [3] sapjoy 2009.12.11 5030
323 문자열 오른쪽에서부터 잘라서 사용하기 [2] 권장원 2009.11.06 6230
322 (-) 부호 값 앞에 붙이기 [6] 권장원 2009.11.06 6473
321 Overview transport requests for all systems and clients [3] file 노름마치 2009.11.05 3676
320 SAP GUI 7.10 patch level 15 [10] file activeman 2009.10.23 10930
319 SAP GUI 7.10 patch level 14 Download Link 입니다. [2] 방배 2009.10.13 12609
» BAPI_PO_CHANGE [1] 노름마치 2009.09.03 8139
317 Mass download version 1.4.4 [4] file 노름마치 2009.08.20 7448
316 테이블 Lock걸렸을때 난감하시죠? [16] file 양키 2009.08.14 6045
315 <img src=d.gif>구매오더 아카이브 방법[추천:e-abap] [14] file 양키 2009.08.14 5754
314 기안문내용 암호화되있죠?? 그거 가져오려면 "Read_Text" [2] file 양키 2009.08.14 4890
313 MM 이동유형 분류표 적어봅니다. [14] file 양키 2009.08.14 4949
312 영업오더 UserExit [5] 한해동안 2009.08.12 5427
311 납품 UserExit [2] 한해동안 2009.08.12 5383
310 대금청구 UserExit [2] 한해동안 2009.08.12 6046
309 유니코드 변환 펑션 [5] 프리틀 2009.07.16 9851
308 SE16N 을 이용하여 Add-On Table 데이타 조정하는 방법 [15] file 노름마치 2009.07.10 5833