SAP BAPI_ADDPERSDATA_CHANGE Function Module for Change additional personal data
BAPI_ADDPERSDATA_CHANGE is a standard bapi addpersdata change SAP function module available within SAP R/3 or S/4 Hana systems, depending on your version and release level. It is used for Change additional personal data processing and below is the pattern details for this FM, showing its interface including any import and export parameters, exceptions etc. there is also a full "cut and paste" ABAP pattern code example, along with implementation ABAP coding, documentation and contribution comments specific to this or related objects.
See here to view full function module documentation and code listing for bapi addpersdata change FM, simply by entering the name BAPI_ADDPERSDATA_CHANGE into the relevant SAP transaction such as SE37 or SE38.
Function Group: OPERS_CA
Program Name: SAPLOPERS_CA
Main Program:
Appliation area:
Release date: N/A
Mode(Normal, Remote etc): Normal Function Module
Update:

Function BAPI_ADDPERSDATA_CHANGE pattern details
In-order to call this FM within your sap programs, simply using the below ABAP pattern details to trigger the function call...or see the full ABAP code listing at the end of this article. You can simply cut and paste this code into your ABAP progrom as it is, including variable declarations.CALL FUNCTION 'BAPI_ADDPERSDATA_CHANGE'"Change additional personal data.
EXPORTING
EMPLOYEENUMBER = "Personnel Number
* SURVEY = "Survey answered
* DISABLEDDATE = "Date of determination of disability status
* LEARNEDDATE = "Date employer learned of disability status
* DESIGCMA = "Designated CMA
* NOCOMMIT = "COMMIT control at BAPI interface
* STANDARDVALUECURR = "Currency amount in BAPI interfaces
* SURVEYPARTICIPATE = "Survey Participation flag
* RELEASEINFO = "Release of Data
* SURVEYSOURCE = "Source of Survey Data
* ABORIGINAL = "Designated groups for Group types
SUBTYPE = "Subtype
* DTY01 = "Designated groups for Group types
* DTY02 = "Designated groups for Group types
* DTY03 = "Designated groups for Group types
* DTY04 = "Designated groups for Group types
* DTY05 = "Designated groups for Group types
* MTY01 = "Designated groups for Group types
* MTY02 = "Designated groups for Group types
* MTY03 = "Designated groups for Group types
* MTY04 = "Designated groups for Group types
* MTY05 = "Designated groups for Group types
OBJECTID = "Object Identification
LOCKINDICATOR = "Lock Indicator for HR Master Data Record
VALIDITYBEGIN = "Start Date
VALIDITYEND = "End Date
RECORDNUMBER = "Number of Infotype Record With Same Key
* ETHNIK = "Ethnic origin
* DISABLED = "Person is disabled
IMPORTING
RETURN = "Return parameter
IMPORTING Parameters details for BAPI_ADDPERSDATA_CHANGE
EMPLOYEENUMBER - Personnel Number
Data type: BAPIP0077-PERNROptional: No
Call by Reference: No ( called with pass by value option)
SURVEY - Survey answered
Data type: BAPIP0077-SURVYOptional: Yes
Call by Reference: No ( called with pass by value option)
DISABLEDDATE - Date of determination of disability status
Data type: BAPIP0077-DISDTOptional: Yes
Call by Reference: No ( called with pass by value option)
LEARNEDDATE - Date employer learned of disability status
Data type: BAPIP0077-DISLEOptional: Yes
Call by Reference: No ( called with pass by value option)
DESIGCMA - Designated CMA
Data type: BAPIP0077-RCITYOptional: Yes
Call by Reference: No ( called with pass by value option)
NOCOMMIT - COMMIT control at BAPI interface
Data type: BAPI_STAND-NO_COMMITOptional: Yes
Call by Reference: No ( called with pass by value option)
STANDARDVALUECURR - Currency amount in BAPI interfaces
Data type: BAPICURR-BAPICURROptional: Yes
Call by Reference: No ( called with pass by value option)
SURVEYPARTICIPATE - Survey Participation flag
Data type: BAPIP0077-SURPAOptional: Yes
Call by Reference: No ( called with pass by value option)
RELEASEINFO - Release of Data
Data type: BAPIP0077-RELEAOptional: Yes
Call by Reference: No ( called with pass by value option)
SURVEYSOURCE - Source of Survey Data
Data type: BAPIP0077-SURSCOptional: Yes
Call by Reference: No ( called with pass by value option)
ABORIGINAL - Designated groups for Group types
Data type: BAPIP0077-ABOTYOptional: Yes
Call by Reference: No ( called with pass by value option)
SUBTYPE - Subtype
Data type: BAPIP0077-SUBTYOptional: No
Call by Reference: No ( called with pass by value option)
DTY01 - Designated groups for Group types
Data type: BAPIP0077-DTY01Optional: Yes
Call by Reference: No ( called with pass by value option)
DTY02 - Designated groups for Group types
Data type: BAPIP0077-DTY02Optional: Yes
Call by Reference: No ( called with pass by value option)
DTY03 - Designated groups for Group types
Data type: BAPIP0077-DTY03Optional: Yes
Call by Reference: No ( called with pass by value option)
DTY04 - Designated groups for Group types
Data type: BAPIP0077-DTY04Optional: Yes
Call by Reference: No ( called with pass by value option)
DTY05 - Designated groups for Group types
Data type: BAPIP0077-DTY05Optional: Yes
Call by Reference: No ( called with pass by value option)
MTY01 - Designated groups for Group types
Data type: BAPIP0077-MTY01Optional: Yes
Call by Reference: No ( called with pass by value option)
MTY02 - Designated groups for Group types
Data type: BAPIP0077-MTY02Optional: Yes
Call by Reference: No ( called with pass by value option)
MTY03 - Designated groups for Group types
Data type: BAPIP0077-MTY03Optional: Yes
Call by Reference: No ( called with pass by value option)
MTY04 - Designated groups for Group types
Data type: BAPIP0077-MTY04Optional: Yes
Call by Reference: No ( called with pass by value option)
MTY05 - Designated groups for Group types
Data type: BAPIP0077-MTY05Optional: Yes
Call by Reference: No ( called with pass by value option)
OBJECTID - Object Identification
Data type: BAPIP0077-OBJPSOptional: No
Call by Reference: No ( called with pass by value option)
LOCKINDICATOR - Lock Indicator for HR Master Data Record
Data type: BAPIP0077-SPRPSOptional: No
Call by Reference: No ( called with pass by value option)
VALIDITYBEGIN - Start Date
Data type: BAPIP0077-BEGDAOptional: No
Call by Reference: No ( called with pass by value option)
VALIDITYEND - End Date
Data type: BAPIP0077-ENDDAOptional: No
Call by Reference: No ( called with pass by value option)
RECORDNUMBER - Number of Infotype Record With Same Key
Data type: BAPIP0077-SEQNROptional: No
Call by Reference: No ( called with pass by value option)
ETHNIK - Ethnic origin
Data type: BAPIP0077-RACKYOptional: Yes
Call by Reference: No ( called with pass by value option)
DISABLED - Person is disabled
Data type: BAPIP0077-DISABOptional: Yes
Call by Reference: No ( called with pass by value option)
EXPORTING Parameters details for BAPI_ADDPERSDATA_CHANGE
RETURN - Return parameter
Data type: BAPIRETURN1Optional: No
Call by Reference: No ( called with pass by value option)
Copy and paste ABAP code example for BAPI_ADDPERSDATA_CHANGE Function Module
The ABAP code below is a full code listing to execute function module POPUP_TO_CONFIRM including all data declarations. The code uses the original data declarations rather than 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 newer method of declaring data variables on the fly. 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), which i why i have stuck to the origianl for this example.| DATA: | ||||
| lv_return | TYPE BAPIRETURN1, " | |||
| lv_employeenumber | TYPE BAPIP0077-PERNR, " | |||
| lv_survey | TYPE BAPIP0077-SURVY, " | |||
| lv_disableddate | TYPE BAPIP0077-DISDT, " | |||
| lv_learneddate | TYPE BAPIP0077-DISLE, " | |||
| lv_desigcma | TYPE BAPIP0077-RCITY, " | |||
| lv_nocommit | TYPE BAPI_STAND-NO_COMMIT, " | |||
| lv_standardvaluecurr | TYPE BAPICURR-BAPICURR, " | |||
| lv_surveyparticipate | TYPE BAPIP0077-SURPA, " | |||
| lv_releaseinfo | TYPE BAPIP0077-RELEA, " | |||
| lv_surveysource | TYPE BAPIP0077-SURSC, " | |||
| lv_aboriginal | TYPE BAPIP0077-ABOTY, " | |||
| lv_subtype | TYPE BAPIP0077-SUBTY, " | |||
| lv_dty01 | TYPE BAPIP0077-DTY01, " | |||
| lv_dty02 | TYPE BAPIP0077-DTY02, " | |||
| lv_dty03 | TYPE BAPIP0077-DTY03, " | |||
| lv_dty04 | TYPE BAPIP0077-DTY04, " | |||
| lv_dty05 | TYPE BAPIP0077-DTY05, " | |||
| lv_mty01 | TYPE BAPIP0077-MTY01, " | |||
| lv_mty02 | TYPE BAPIP0077-MTY02, " | |||
| lv_mty03 | TYPE BAPIP0077-MTY03, " | |||
| lv_mty04 | TYPE BAPIP0077-MTY04, " | |||
| lv_mty05 | TYPE BAPIP0077-MTY05, " | |||
| lv_objectid | TYPE BAPIP0077-OBJPS, " | |||
| lv_lockindicator | TYPE BAPIP0077-SPRPS, " | |||
| lv_validitybegin | TYPE BAPIP0077-BEGDA, " | |||
| lv_validityend | TYPE BAPIP0077-ENDDA, " | |||
| lv_recordnumber | TYPE BAPIP0077-SEQNR, " | |||
| lv_ethnik | TYPE BAPIP0077-RACKY, " | |||
| lv_disabled | TYPE BAPIP0077-DISAB. " |
|   CALL FUNCTION 'BAPI_ADDPERSDATA_CHANGE' "Change additional personal data |
| EXPORTING | ||
| EMPLOYEENUMBER | = lv_employeenumber | |
| SURVEY | = lv_survey | |
| DISABLEDDATE | = lv_disableddate | |
| LEARNEDDATE | = lv_learneddate | |
| DESIGCMA | = lv_desigcma | |
| NOCOMMIT | = lv_nocommit | |
| STANDARDVALUECURR | = lv_standardvaluecurr | |
| SURVEYPARTICIPATE | = lv_surveyparticipate | |
| RELEASEINFO | = lv_releaseinfo | |
| SURVEYSOURCE | = lv_surveysource | |
| ABORIGINAL | = lv_aboriginal | |
| SUBTYPE | = lv_subtype | |
| DTY01 | = lv_dty01 | |
| DTY02 | = lv_dty02 | |
| DTY03 | = lv_dty03 | |
| DTY04 | = lv_dty04 | |
| DTY05 | = lv_dty05 | |
| MTY01 | = lv_mty01 | |
| MTY02 | = lv_mty02 | |
| MTY03 | = lv_mty03 | |
| MTY04 | = lv_mty04 | |
| MTY05 | = lv_mty05 | |
| OBJECTID | = lv_objectid | |
| LOCKINDICATOR | = lv_lockindicator | |
| VALIDITYBEGIN | = lv_validitybegin | |
| VALIDITYEND | = lv_validityend | |
| RECORDNUMBER | = lv_recordnumber | |
| ETHNIK | = lv_ethnik | |
| DISABLED | = lv_disabled | |
| IMPORTING | ||
| RETURN | = lv_return | |
| . " BAPI_ADDPERSDATA_CHANGE | ||
ABAP code using 7.40 inline data declarations to call FM BAPI_ADDPERSDATA_CHANGE
The below ABAP code uses the newer in-line data declarations. This allows you to see the coding differences/benefits of the later inline syntax. Please note some of the newer syntax below, such as the @DATA is not available until 4.70 EHP 8.| "SELECT single PERNR FROM BAPIP0077 INTO @DATA(ld_employeenumber). | ||||
| "SELECT single SURVY FROM BAPIP0077 INTO @DATA(ld_survey). | ||||
| "SELECT single DISDT FROM BAPIP0077 INTO @DATA(ld_disableddate). | ||||
| "SELECT single DISLE FROM BAPIP0077 INTO @DATA(ld_learneddate). | ||||
| "SELECT single RCITY FROM BAPIP0077 INTO @DATA(ld_desigcma). | ||||
| "SELECT single NO_COMMIT FROM BAPI_STAND INTO @DATA(ld_nocommit). | ||||
| "SELECT single BAPICURR FROM BAPICURR INTO @DATA(ld_standardvaluecurr). | ||||
| "SELECT single SURPA FROM BAPIP0077 INTO @DATA(ld_surveyparticipate). | ||||
| "SELECT single RELEA FROM BAPIP0077 INTO @DATA(ld_releaseinfo). | ||||
| "SELECT single SURSC FROM BAPIP0077 INTO @DATA(ld_surveysource). | ||||
| "SELECT single ABOTY FROM BAPIP0077 INTO @DATA(ld_aboriginal). | ||||
| "SELECT single SUBTY FROM BAPIP0077 INTO @DATA(ld_subtype). | ||||
| "SELECT single DTY01 FROM BAPIP0077 INTO @DATA(ld_dty01). | ||||
| "SELECT single DTY02 FROM BAPIP0077 INTO @DATA(ld_dty02). | ||||
| "SELECT single DTY03 FROM BAPIP0077 INTO @DATA(ld_dty03). | ||||
| "SELECT single DTY04 FROM BAPIP0077 INTO @DATA(ld_dty04). | ||||
| "SELECT single DTY05 FROM BAPIP0077 INTO @DATA(ld_dty05). | ||||
| "SELECT single MTY01 FROM BAPIP0077 INTO @DATA(ld_mty01). | ||||
| "SELECT single MTY02 FROM BAPIP0077 INTO @DATA(ld_mty02). | ||||
| "SELECT single MTY03 FROM BAPIP0077 INTO @DATA(ld_mty03). | ||||
| "SELECT single MTY04 FROM BAPIP0077 INTO @DATA(ld_mty04). | ||||
| "SELECT single MTY05 FROM BAPIP0077 INTO @DATA(ld_mty05). | ||||
| "SELECT single OBJPS FROM BAPIP0077 INTO @DATA(ld_objectid). | ||||
| "SELECT single SPRPS FROM BAPIP0077 INTO @DATA(ld_lockindicator). | ||||
| "SELECT single BEGDA FROM BAPIP0077 INTO @DATA(ld_validitybegin). | ||||
| "SELECT single ENDDA FROM BAPIP0077 INTO @DATA(ld_validityend). | ||||
| "SELECT single SEQNR FROM BAPIP0077 INTO @DATA(ld_recordnumber). | ||||
| "SELECT single RACKY FROM BAPIP0077 INTO @DATA(ld_ethnik). | ||||
| "SELECT single DISAB FROM BAPIP0077 INTO @DATA(ld_disabled). | ||||
Search for further information about these or an SAP related objects