The ABAP SELECT statement is the most fundamental function of writing ABAP programs within SAP, allowing the retrieval of
data from SAP database tables. Below are a few examples of the various ways of selecting data ready for processing.
Also check out the new @DATA inline syntax for selecting data into an internal table,
without the need for the separate data declaration
i.e. select ebeln, ebelp, statu, aedat, matnr, menge, meins, netpr, peinh up to 10 rows from ekpo into TABLE @DATA(it_ekko_inline).
*ABAP Code to demonstrate select into internal table command TYPES: BEGIN OF t_bkpf, * include structure bkpf. bukrs LIKE bkpf-bukrs, belnr LIKE bkpf-belnr, gjahr LIKE bkpf-gjahr, bldat LIKE bkpf-bldat, monat LIKE bkpf-monat, budat LIKE bkpf-budat, xblnr LIKE bkpf-xblnr, awtyp LIKE bkpf-awtyp, awkey LIKE bkpf-awkey, END OF t_bkpf. DATA: it_bkpf TYPE STANDARD TABLE OF t_bkpf INITIAL SIZE 0, wa_bkpf TYPE t_bkpf. TYPES: BEGIN OF t_bseg, *include structure bseg. bukrs LIKE bseg-bukrs, belnr LIKE bseg-belnr, gjahr LIKE bseg-gjahr, buzei LIKE bseg-buzei, mwskz LIKE bseg-mwskz, "Tax code umsks LIKE bseg-umsks, "Special G/L transaction type prctr LIKE bseg-prctr, "Profit Centre hkont LIKE bseg-hkont, "G/L account xauto LIKE bseg-xauto, koart LIKE bseg-koart, dmbtr LIKE bseg-dmbtr, mwart LIKE bseg-mwart, hwbas LIKE bseg-hwbas, aufnr LIKE bseg-aufnr, projk LIKE bseg-projk, shkzg LIKE bseg-shkzg, kokrs LIKE bseg-kokrs, END OF t_bseg. DATA: it_bseg TYPE STANDARD TABLE OF t_bseg INITIAL SIZE 0, wa_bseg TYPE t_bseg. DATA: it_ekko TYPE STANDARD TABLE OF ekko. *Select all fields of a SAP database table into in itab SELECT * FROM ekko INTO TABLE it_ekko. *Inline Version - (difference is you don't need the data declaration above) select * from ekpo into TABLE @DATA(it_ekko2). "see here for more info and examples of the inline @DATA & DATA syntax *Select directly into an internal table SELECT bukrs belnr gjahr buzei mwskz umsks prctr hkont xauto koart dmbtr mwart hwbas aufnr projk shkzg kokrs FROM bseg INTO TABLE it_bseg. * Select directly into an internal table where fields are in a * different order or not all fields are specified SELECT bukrs belnr gjahr buzei mwskz umsks prctr hkont xauto koart dmbtr mwart hwbas aufnr projk shkzg kokrs FROM bseg INTO CORRESPONDING FIELDS OF TABLE it_bseg.
*Select... endselect command SELECT bukrs belnr gjahr buzei mwskz umsks prctr hkont xauto koart dmbtr mwart hwbas aufnr projk shkzg kokrs FROM bseg INTO wa_bseg. APPEND wa_bseg TO it_bseg. ENDSELECT.
*Select FOR ALL ENTRIES command SELECT bukrs belnr gjahr bldat monat budat xblnr awtyp awkey UP TO 100 ROWS FROM bkpf INTO TABLE it_bkpf. IF sy-subrc EQ 0. * The FOR ALL ENTRIES command only retrieves data which matches * entries within a particular internal table. SELECT bukrs belnr gjahr buzei mwskz umsks prctr hkont xauto koart dmbtr mwart hwbas aufnr projk shkzg kokrs FROM bseg INTO TABLE it_bseg FOR ALL ENTRIES IN it_bkpf WHERE bukrs EQ it_bkpf-bukrs AND belnr EQ it_bkpf-belnr AND gjahr EQ it_bkpf-gjahr. ENDIF.
*Select Single with full table key retrieves ONLY one row if available SELECT * "all fields FROM bseg INTO TABLE it_bseg WHERE bukrs EQ wa_bseg-bukrs AND belnr EQ wa_bseg-belnr AND gjahr EQ wa_bseg-gjahr AND buzei EQ wa_bseg-BUZEI *Select Single without full table key. Syntactically correct and still retrieves ONLY one row if available SELECT * "all fields FROM bseg INTO TABLE it_bseg WHERE bukrs EQ wa_bseg-bukrs AND belnr EQ wa_bseg-belnr.
*Select UP TO 1 ROWS - Retrieves ONLY one row if available SELECT * "select all fields FROM bseg UP TO 1 ROWS INTO TABLE it_bseg WHERE bukrs EQ wa_bseg-bukrs AND belnr EQ wa_bseg-belnr. *Select UP TO 1000 ROWS - Retrieves no more than 1000 rows SELECT * "select all fields FROM bseg UP TO 1000 ROWS INTO TABLE it_bseg WHERE bukrs EQ wa_bseg-bukrs AND belnr EQ wa_bseg-belnr.