Using the Oracle Database Gateway for DRDA involves connecting to the corresponding gateway system and the remote DRDA database associated with the gateway. It is important to understand how to process and use database links. Database links are discussed in detail in the Oracle Database Reference. Read the database link information in that guide to understand database link processing. Then proceed to read this chapter to understand how to set up a database link to a remote DRDA database.
This chapter contains the following sections:
The database and application administrators of a distributed database system are responsible for managing the database links that define paths to the DRDA database. The tasks are as follows:
To create a database link and define a path to a remote database, use the
DATABASE LINK statement. The
CONNECT TO clause specifies the remote user ID and password to use when creating a session in the remote database. The
USING clause points to a tnsnames.ora connect descriptor.
Note:If you do not specify a user ID and a password in the
CONNECT TOclause, then the Oracle database user ID and password are used.
See Also:" Refer to Chapter 15, "Security Considerations" in Oracle Database Gateway Installation and Configuration Guide for AIX 5L Based Systems (64-Bit), HP-UX PA-RISC (64-Bit), Solaris Operating System (SPARC 64-Bit), Linux x86, and Linux x86-64 or Oracle Database Gateway Installation and Configuration Guide for Microsoft Windows for details.
The following example creates a database link to access information in the DRDA server database:
CREATE PUBLIC DATABASE LINK dblink CONNECT TO userid IDENTIFIED BY password USING 'tns_name_entry';
dblink is the complete database link name.
user id is the user ID used to establish a session in the remote database. This user ID must be a valid DRDA server user ID. It must be authorized to any table or file on the DRDA server that is referenced in the SQL commands. The user ID must be lesser than eight characters.
password is the password used to establish a session in the remote database. This password must be a valid DRDA server password. The password must be lesser than eight characters.
DROP PUBLIC DATABASE LINK dblink;
Note:A database link should not be dropped if it is required to resolve an in-doubt distributed transaction. Refer to Oracle Database Administrator's Guide for additional information about dropping database links.
See Also:Oracle Database Administrator's Guide for additional information about dropping database links
The data dictionary of each database stores the definitions of all the database links in that database. The
USER_DB_LINKS data dictionary view shows the defined database links. The
ALL_DB_LINKS data dictionary views show all accessible (public and private) database links.
You can limit the number of connections from a user process to remote databases with the parameter
OPEN_LINKS. This parameter controls the number of remote connections that any single user process can concurrently use with a single SQL statement. Refer to Oracle Database Reference for additional information about limiting the number of active database links.
Log in to the Oracle database to access the gateway
For example, use:
CREATE PUBLIC DATABASE LINK DRDA CONNECT TO ORADRDA IDENTIFIED BY oracle_pw USING 'tns_name_entry'
This query fetches the
TABLE file in the library
SECURE, using the name ORACLE as the DRDA server user profile. The
ORACLE user profile must have the appropriate privileges on the DRDA server to access the
SELECT * FROM SECURE.TABLE@DRDA
The following is an example of the error messages that are displayed if insufficient privileges are displayed:
Nothing specific to DRDA or to the gateway controls the access to AS/400 files and file members. However, DB2/400 uses a naming convention that implies that the file member name is the same as the name of the file being addressed. For example, accessing
schema.table implies that table is the file name and also that table is the file member name being accessed.
To access file members with names that differ from the associated file name, you must create a view within the file so that DB2/400 can reference the correct file member.
One method for creating this view involves issuing the console command
Create Logical File (
CRTLF). This action creates a logical association between the file name and the file member name.
See Also:For additional information, refer to the AS/400 Command documentation or to the DB2/400 SQL reference document.
You can provide complete data, location, and network transparency by using the synonym feature of Oracle database. When a synonym is defined, the user need not know the underlying table or network protocol being used. A synonym can be public, which means it is available to all Oracle users. A synonym can also be defined as private, available only to the user who created it. Refer to Oracle Database Reference for details on the synonym feature.
The following statement creates a system-wide synonym for the
EMP file in the DRDA server with ownership of
The Oracle Database Gateway technology enables the execution of distributed queries that join Oracle database and DRDA servers and any other data store for which Oracle provides a gateway. These complex operations can be completely transparent to the users requesting the data.
The distributed query optimizer (DQO) capability can provide better performance of distributed queries. Statistical data regarding tables from DRDA server is retrieved and passed to the Oracle database. The DQO capability is enabled or disabled by the
DRDA_OPTIMIZE_QUERY parameter. Refer to "DRDA_OPTIMIZE_QUERY".
The following example joins data between an Oracle database, DB2/OS390, and a DRDA server:
SELECT o.custname, p.projno, e.ename, sum(e.rate*p.hours) FROM orders@DB2 o, EMP@ORACLE7 e, projects@DRDA p WHERE o.projno = p.projno AND p.empno = e.empno GROUP BY o.custname, p.projno, e.ename
A combination of views and synonyms, using the following SQL statements, keeps the process of distributed queries transparent to the user:
CREATE SYNONYM orders for orders@DB2; CREATE SYNONYM PROJECTS for PROJECTS@DRDA; CREATE VIEW details (custname,projno,ename,spend) AS SELECT o.custname, p.projno, e.ename, sum(e.rate*p.hours) FROM orders o, EMP e, projects p WHERE o.projno = p.projno AND p.empno = e.empno GROUP BY o.custname, p.projno, e.ename
The following SQL statement retrieves information from these three data stores in one command:
SELECT * FROM DETAILS;
The results of this command are:
CUSTNAME PROJNO ENAME SPEND --------- --------- --------- --------- ABC Co. 1 Jones 400 ABC Co. 1 Smith 180 XYZ Inc. 2 Jones 400 XYZ Inc. 2 Smith 180
To fully participate in a two-phase commit transaction, a server must support the
PREPARE TRANSACTION statement. The
PREPARE TRANSACTION statement ensures that all participating databases are prepared to
COMMIT or to
ROLLBACK a specific unit of work.
Oracle database supports the
PREPARE TRANSACTION statement. Any number of Oracle database can participate in a distributed two-phase commit transaction. The
PREPARE TRANSACTION statement is performed automatically when a
COMMIT is issued explicitly by an application or implicitly at the normal end of the application.
The gateway does not support the
PREPARE TRANSACTION statement. This limits the two-phase commit protocol when the gateway participates in a distributed transaction. The gateway becomes the commit focal point site of a distributed transaction. The gateway is configured as commit/confirm, so it is always the commit point site, regardless of the commit point strength setting. The gateway commits the unit of work after verifying that all Oracle databases in the transaction have successfully committed their work. The gateway must coordinate the distributed transaction, so only one gateway can participate in an two-phase commit transaction.
Two-phase commit transactions are recorded in the
ORADRDA.ORACLE2PC table, which is created during installation. This table is created when the o2pc.sql script is run. The owner of this table also owns the package. Refer to "DRDA Gateway Package Binding Considerations" on Oracle Database Gateway Installation and Configuration Guide for AIX 5L Based Systems (64-Bit), HP-UX PA-RISC (64-Bit), Solaris Operating System (SPARC 64-Bit), Linux x86, and Linux x86-64 or Oracle Database Gateway Installation and Configuration Guide for Microsoft Windows, depending on your platform, for more information.
ORACLE2PC table is used to record the status of a gateway transaction, this table must be in at the database where the DRDA update takes place. Therefore, all updates that take place over the gateway must be local to the IBM database.
Note:Updates to the
ORACLE2PCtable cannot be part of an IBM distributed transaction.
For additional information about the two-phase commit process, refer to Oracle Database Administrator's Guide.
The read-only option can provide improved performance and security. This improved performance depends on your configuration and parameter selections. A Gateway Initialization Parameter,
DRDA_READ_ONLY, controls whether the gateway is enabled in this mode.
If you enable the read-only option, then only queries (
SELECT statements) are allowed by the gateway. The capabilities that control whether updates are allowed by the gateway are disabled. These capabilities include
DELETE and stored-procedure support (pass-through SQL and DB2 stored procedures). Statements attempting to modify records on the DRDA server are rejected.
Oracle recommends that you should not routinely switch between settings of the
DRDA_READ_ONLY parameter. If you need both the update and
DRDA_READ_ONLY functionality, then you should create two separate instances of the gateway with different read-only settings.
Oracle Database Gateway for DRDA can use the Oracle snapshot feature to automatically replicate non-Oracle data into Oracle database. The complete refresh capability of Oracle snapshot can be used to propagate a complete copy or a subset of the non-Oracle data into Oracle database at user-defined intervals.
INSERT INTO DRDA_table SELECT * FROM local_table
then the following message is displayed:
To copy data from your Oracle database to the DRDA server, use:
COPY FROM username/password@connect_identifier - INSERT destination_table - USING query
COPY FROM scott/tiger@ORACLE - INSERT scott.EMP@DRDA - USING SELECT * FROM EMP
COPY command supports
REPLACE commands. However,
INSERT is the only command supported when copying to the DRDA server. For more information about the
COPY command, refer to SQL*Plus User's Guide and Reference.
CREATE TABLE command enables you to copy data from a DRDA server to Oracle database. To create a table on your Oracle database and to insert rows from a DRDA server table, use:
CREATE TABLE table_name AS query
The following example creates the table
EMP in your local Oracle database and inserts the rows from the
EMP table on the DRDA server:
CREATE TABLE EMP AS SELECT * FROM scott.EMP@DRDA
Alternatively, you can use the SQL*Plus
COPY command to copy data from a DRDA server to Oracle database. For more information about the
COPY command, refer to SQL*Plus User's Guide and Reference.
SQL statements issued through the gateway can be changed before reaching the DRDA database. These changes are made to make the format acceptable to the gateway or to make Oracle SQL compatible with DRDA server SQL. Oracle database and the gateway can change the statements depending on the situation.
For various reasons, you might need to assess whether the gateway has altered the statement correctly or whether the statement could be rewritten to improve performance. SQL tracing is a feature that allows you to view the changes made to a SQL statement by the Oracle database or the gateway.
SQL tracing reduces gateway performance. Use tracing only while testing and debugging your application. Do not enable SQL tracing when the application is running in a production environment. For more information about enabling SQL tracing, refer to the section on "SQL Tracing and the Gateway" in Chapter 5, "Error Messages, Diagnosis, and Reporting".