SAP Function Modules

DD_FORKEY_SQLSTATEMENT SAP Function module - DD: Foreign key check for values in single fields







DD_FORKEY_SQLSTATEMENT is a standard SAP function module available within R/3 SAP systems depending on your version and release level. Below is the pattern details for this FM showing its interface including any import and export parameters, exceptions etc as well as any documentation contributions (Comments) specific to the object.

See here to view full function module documentation and code listing, simply by entering the name DD_FORKEY_SQLSTATEMENT into the relevant SAP transaction such as SE37 or SE80.

Associated Function Group: SDFC
Released Date: Not Released
Processing type: Normal fucntion module
Normal function module settings


Pattern for FM DD_FORKEY_SQLSTATEMENT - DD FORKEY SQLSTATEMENT





CALL FUNCTION 'DD_FORKEY_SQLSTATEMENT' "DD: Foreign key check for values in single fields
  EXPORTING
    table_name =                " dd02l-tabname
    field_name =                " dd03l-fieldname
*   syst_mandt = 'X'            " ddrefstruc-bool
  TABLES
    statement =                 " ddwherecnd
  EXCEPTIONS
    FORKEY_NOT_DEFINED = 1      "
    TABLE_NOT_ACTIVE = 2        "
    UNKNOWN_FIELD = 3           "
    .  "  DD_FORKEY_SQLSTATEMENT

ABAP code example for Function Module DD_FORKEY_SQLSTATEMENT





The ABAP code below is a full code listing to execute function module DD_FORKEY_SQLSTATEMENT including all data declarations. The code uses the latest in-line data DECLARATION SYNTAX but I have included an ABAP code snippet at the end to show how declarations would look using the original method of declaring data variables up front. This will allow you to compare and fully understand the new inline method. Please note some of the newer syntax such as the @DATA is not available until a later 4.70 service pack (SP8).

DATA:
it_statement  TYPE STANDARD TABLE OF DDWHERECND,"TABLES PARAM
wa_statement  LIKE LINE OF it_statement .


SELECT single TABNAME
FROM DD02L
INTO @DATA(ld_table_name).


SELECT single FIELDNAME
FROM DD03L
INTO @DATA(ld_field_name).


DATA(ld_syst_mandt) = some text here

"populate fields of struture and append to itab
append wa_statement to it_statement. . CALL FUNCTION 'DD_FORKEY_SQLSTATEMENT' EXPORTING table_name = ld_table_name field_name = ld_field_name * syst_mandt = ld_syst_mandt TABLES statement = it_statement EXCEPTIONS FORKEY_NOT_DEFINED = 1 TABLE_NOT_ACTIVE = 2 UNKNOWN_FIELD = 3 . " DD_FORKEY_SQLSTATEMENT
IF SY-SUBRC EQ 0. "All OK ELSEIF SY-SUBRC EQ 1. "Exception "Add code for exception here ELSEIF SY-SUBRC EQ 2. "Exception "Add code for exception here ELSEIF SY-SUBRC EQ 3. "Exception "Add code for exception here ENDIF.







ABAP code to compare 7.40 inline data declaration with original syntax

The below ABAP code uses the older none in-line data declarations. This allows you to see the coding differences/benefits of the later inline syntax. It may also be useful if you are using an older version of SAP as some of the newer syntax above, such as the @DATA is not available until 4.70 EHP 8.

DATA:
ld_table_name  TYPE DD02L-TABNAME ,
it_statement  TYPE STANDARD TABLE OF DDWHERECND ,
wa_statement  LIKE LINE OF it_statement,
ld_field_name  TYPE DD03L-FIELDNAME ,
ld_syst_mandt  TYPE DDREFSTRUC-BOOL .


SELECT single TABNAME
FROM DD02L
INTO ld_table_name.


"populate fields of struture and append to itab
append wa_statement to it_statement.

SELECT single FIELDNAME
FROM DD03L
INTO ld_field_name.


ld_syst_mandt = some text here

Contribute (Add Comments)

Please help keep this info upto date and use the comments section below to add useful hints, tips and information specific to this SAP function. This will then be available for you and other users to easily find by simply searching on the object name DD_FORKEY_SQLSTATEMENT or its description.