SAP ENQUEUE_E_JBNIPL Function Module for Request lock for object E_JBNIPL









ENQUEUE_E_JBNIPL is a standard enqueue e jbnipl SAP function module available within SAP R/3 or S/4 Hana systems, depending on your version and release level. It is used for Request lock for object E_JBNIPL 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 enqueue e jbnipl FM, simply by entering the name ENQUEUE_E_JBNIPL into the relevant SAP transaction such as SE37 or SE38.

Function Group: /1BCDWBEN/JEN0001
Program Name: /1BCDWBEN/SAPLJEN0001
Main Program:
Appliation area:
Release date: N/A
Mode(Normal, Remote etc): Normal Function Module
Update:



Function ENQUEUE_E_JBNIPL 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 'ENQUEUE_E_JBNIPL'"Request lock for object E_JBNIPL
EXPORTING
* MODE_JBNIPL = 'S' "Lock mode for table JBNIPL
* _COLLECT = ' ' "Initially only collect lock
* MODE_JBNIPL_DATA = 'S' "Lock mode for table JBNIPL_DATA
* MANDT = SY-MANDT "01th enqueue argument
* IDNUM = "02th enqueue argument
* PERIOD_DATE = "03th enqueue argument
* X_IDNUM = ' ' "Fill argument 02 with initial value?
* X_PERIOD_DATE = ' ' "Fill argument 03 with initial value?
* _SCOPE = '2' "
* _WAIT = ' ' "

EXCEPTIONS
FOREIGN_LOCK = 1 SYSTEM_FAILURE = 2
.



IMPORTING Parameters details for ENQUEUE_E_JBNIPL

MODE_JBNIPL - Lock mode for table JBNIPL

Data type: ENQMODE
Default: 'S'
Optional: Yes
Call by Reference: No ( called with pass by value option)

_COLLECT - Initially only collect lock

Data type: DDENQCOLL
Default: ' '
Optional: Yes
Call by Reference: No ( called with pass by value option)

MODE_JBNIPL_DATA - Lock mode for table JBNIPL_DATA

Data type: ENQMODE
Default: 'S'
Optional: Yes
Call by Reference: No ( called with pass by value option)

MANDT - 01th enqueue argument

Data type: JBNIPL-MANDT
Default: SY-MANDT
Optional: Yes
Call by Reference: No ( called with pass by value option)

IDNUM - 02th enqueue argument

Data type: JBNIPL-IDNUM
Optional: Yes
Call by Reference: No ( called with pass by value option)

PERIOD_DATE - 03th enqueue argument

Data type: JBNIPL_DATA-PERIOD_DATE
Optional: Yes
Call by Reference: No ( called with pass by value option)

X_IDNUM - Fill argument 02 with initial value?

Data type:
Default: SPACE
Optional: Yes
Call by Reference: No ( called with pass by value option)

X_PERIOD_DATE - Fill argument 03 with initial value?

Data type:
Default: SPACE
Optional: Yes
Call by Reference: No ( called with pass by value option)

_SCOPE -

Data type:
Default: '2'
Optional: Yes
Call by Reference: No ( called with pass by value option)

_WAIT -

Data type:
Default: SPACE
Optional: Yes
Call by Reference: No ( called with pass by value option)

EXCEPTIONS details

FOREIGN_LOCK - Object already locked

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

SYSTEM_FAILURE - Internal error from enqueue server

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

Copy and paste ABAP code example for ENQUEUE_E_JBNIPL 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_mode_jbnipl  TYPE ENQMODE, "   'S'
lv_foreign_lock  TYPE ENQMODE, "   
lv__collect  TYPE DDENQCOLL, "   ' '
lv_system_failure  TYPE DDENQCOLL, "   
lv_mode_jbnipl_data  TYPE ENQMODE, "   'S'
lv_mandt  TYPE JBNIPL-MANDT, "   SY-MANDT
lv_idnum  TYPE JBNIPL-IDNUM, "   
lv_period_date  TYPE JBNIPL_DATA-PERIOD_DATE, "   
lv_x_idnum  TYPE JBNIPL_DATA, "   SPACE
lv_x_period_date  TYPE JBNIPL_DATA, "   SPACE
lv__scope  TYPE JBNIPL_DATA, "   '2'
lv__wait  TYPE JBNIPL_DATA. "   SPACE

  CALL FUNCTION 'ENQUEUE_E_JBNIPL'  "Request lock for object E_JBNIPL
    EXPORTING
         MODE_JBNIPL = lv_mode_jbnipl
         _COLLECT = lv__collect
         MODE_JBNIPL_DATA = lv_mode_jbnipl_data
         MANDT = lv_mandt
         IDNUM = lv_idnum
         PERIOD_DATE = lv_period_date
         X_IDNUM = lv_x_idnum
         X_PERIOD_DATE = lv_x_period_date
         _SCOPE = lv__scope
         _WAIT = lv__wait
    EXCEPTIONS
        FOREIGN_LOCK = 1
        SYSTEM_FAILURE = 2
. " ENQUEUE_E_JBNIPL




ABAP code using 7.40 inline data declarations to call FM ENQUEUE_E_JBNIPL

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.

DATA(ld_mode_jbnipl) = 'S'.
 
 
DATA(ld__collect) = ' '.
 
 
DATA(ld_mode_jbnipl_data) = 'S'.
 
"SELECT single MANDT FROM JBNIPL INTO @DATA(ld_mandt).
DATA(ld_mandt) = SY-MANDT.
 
"SELECT single IDNUM FROM JBNIPL INTO @DATA(ld_idnum).
 
"SELECT single PERIOD_DATE FROM JBNIPL_DATA INTO @DATA(ld_period_date).
 
DATA(ld_x_idnum) = ' '.
 
DATA(ld_x_period_date) = ' '.
 
DATA(ld__scope) = '2'.
 
DATA(ld__wait) = ' '.
 


Search for further information about these or an SAP related objects



Comments on this SAP object

What made you want to lookup this SAP object? Please tell us what you were looking for and anything you would like to be included on this page!