![]() |
![]() |
ALLBASE/SQL COBOL Application Programming Guide: HP 9000 Computer Systems > Chapter 1 Getting Started with ALLBASE/SQL Programming in COBOL![]() ALLBASE/SQL Program Execution |
|
When an ALLBASE/SQL program is first created, it can only be executed by the module OWNER or a DBA. In addition, it can only operate on the DBEnvironment used at preprocessing time if a module was generated. If no module was generated because the SQL commands embedded in the program are only commands for which no sections are created, the program can be run against any DBEnvironment. To make the program executable by other users in other DBEnvironments, you do the following:
When the preprocessor stores a module in a DBEnvironment, it also creates a file containing a copy of the module, which can be installed into another DBEnvironment. You use the INSTALL command in ISQL to install the module in another DBEnvironment.
ISQL copies the module from the installable module file named mysource.sqlm into a DBEnvironment named somedbe. During installation, ALLBASE/SQL marks each section in the module valid or invalid, depending on the current objects and authorities in somedbe. To use the INSTALL command, you need to be able to start a DBE session in the DBEnvironment that is to contain the new module. If you are replacing an earlier module with the same name, make sure no other users are accessing the module. To avoid problems, install modules while connected to the DBEnvironment in single-user mode. At run time, embedded SQL commands are executed only if the original module owner has the authority to execute them. Therefore, you need to grant required authorities to the module owner in the production DBEnvironment. If module pgmr1.somemod contains a SELECT command for table PURCHDB.PARTS, the following grant would ensure valid owner authorization:
If pgmr1 had DBA authority, he could have assigned ownership of the module to another owner at preprocessing time by using the -o option:
In this case, ownership belongs to a class, purchdb. Only an individual with DBA authority can maintain this program, and runtime authorization would be established as follows:
In order to execute an ALLBASE/SQL program you must be able to start any DBE session initiated in the program. You must also have one of the following authorities in the DBEnvironment accessed by the program:
A DBA must grant the authority to start a DBE session. In most cases, application programs start a DBE session with the CONNECT command, so CONNECT authorization is sufficient:
If you have module OWNER or DBA authority, you can grant RUN authority:
Now somelogin can run program someprog.r:
If the program contains the SQLEXPLAIN command, the ALLBASE/SQL message catalog must be available at run time. SQLEXPLAIN obtains warning and error messages from the catalog. The ALLBASE/SQL message catalog resides in /usr/lib/nls/n-computer/hpsqlcat. Once the ALLBASE/SQL message catalog is installed and the appropriate DBEnvironment is identified, the preprocessor or program can be executed.
At run time, an ALLBASE/SQL program interacts with the DBEnvironment as illustrated in Figure 1-6. All the COBOL statements inserted by the preprocessor and the stored sections automatically handle database operations, including providing the application program with status information after SQL commands are executed. SQL commands that have a stored section are executed if the section is valid at run time or can be validated by ALLBASE/SQL at run time. SQL commands that are not known until run time can also be processed by an application program. These SQL commands, known as dynamic commands, are entered by the user at run time rather than embedded in the source code at programming time. ALLBASE/SQL converts these commands into interpretable SQL instructions at run time rather than at preprocessing time. Sections and other instructions created for dynamic data manipulation commands are deleted at the end of the transaction. |