Transfer of handle to database connection between the running ESL scripts
A transfer of handle to database connection between ESL scripts may be done by RPC procedures. In declaration of RPC procedure, you have to tag the parameter that represents the handle to database connection by enumerated type DB_HANDLE. An algorithm is contingent on the existence of database connection. If handle to database connection is an invalid value or it points to missing database connection, the algorithm ends with error.
The enumerated type DB_HANDLE is INT.
RPC procedure declaration:
RPC PROCEDURE ProcName [([IN] DB_HANDLE _db_handle[,_db_handle2, ...] [IN] DB_HANDLE _db_handle3]...)] ;actions END ProcName
_db_handle that can be transferred between ESL scripts is created by these actions: DB_CONNECT, PG_DISCONNECT, SQL_CONNECT, DB_TRANS_OPEN.
Notes:
- The owner of data container can be only one ESL script, which also ensures the cancelling of this handle.
- Handle to database connection can not be transferred between ESL scripts of different processes.
- When calling RPC procedure, if you use the value that is not a handle to
database connection on the place for a formal parameter DB_HANDLE, ESL script
will search handle according to an input value:
- If database connection, tagged by input value, exists, the script transfers it.
- If database connection, tagged by input value, does not exist, ESL script
displays an error.
INT _db_handle _db_handle := 5 CALL [objIdent] INSERT (_db_handle) ON procIdent
- If the input value, representing handle, is invalid, the calling Esl script ends with RunTime error.
- If the calling of RPC procedure is asynchronous, the database
connection is
terminated in this script. Then ESL script that has been called becomes the
owner of this connection:
****************** ; ESL script that is called RPC PROCEDURE InsertToDB(DB_HANDLE _handle) ..... END InsertToDB *************** ; ESL script that is calling INT _db_handle CALL[...] InsertToDB(_db_handle) ASYNC ON .... ; after this calling, handle to database connection will terminate in this script, the called ESL script becomes the owner *****************
- If the calling RPC procedure is synchronous, there are two options:
- If the formal parameter, which represents DB_HANDL, is tagged by the key
word
IN,
when calling the RPC procedure, the ESL script containing the declaration of
called RPC procedure will be permanently the owner of handle to
database connection.
****************** ; ESL script that is called RPC PROCEDURE InsertToDB(IN DB_HANDLE _handle) ..... END InsertToDB *************** ; ESL script that is calling INT _db_handle CALL[...] InsertToDB(_db_handle) ON .... ; after this calling the database connection is terminated in this script, the called ESL script becomes the owner ***************
- If the formal parameter, which represents DB_HANDLE, is not tagged by
the key word IN, when calling RPC procedure, ESL script containing the
declaration of called RPC procedure will be the temporal owner of handle
to database connection. After finishing the called RPC procedure, the script,
from which the RPC procedure has been called, will become the owner.
****************** ; ESL script that is called RPC PROCEDURE InsertToDB(DB_HANDLE _handle) ..... END InsertToDB *************** ; ESL script that is calling INT _db_handle CALL[...] InsertToDB(_db_handle) SYNC ON .... ; after this calling, ESL script, that is calling, is till the owner of database connection ***************
- If the formal parameter, which represents DB_HANDL, is tagged by the key
word
IN,
when calling the RPC procedure, the ESL script containing the declaration of
called RPC procedure will be permanently the owner of handle to
database connection.
Related pages:
Pridať komentár