PK r>Aoa,mimetypeapplication/epub+zipPKr>AiTunesMetadata.plist] artistName Oracle Corporation book-info cover-image-hash 541692140 cover-image-path OEBPS/dcommon/oracle-logo.jpg package-file-hash 320093245 publisher-unique-id E11050-01 unique-id 834995387 genre Oracle Documentation itemName Oracle® Database Heterogeneous Connectivity User's Guide, 11g Release 2 (11.2) releaseDate 2009-07-31T22:45:58Z year 2009 PKAzͷb]PKr>AMETA-INF/container.xml PKYuPKr>AOEBPS/cover.htmO Cover

Oracle Corporation

PK[pTOPKr>AOEBPS/whatsnew.htm What's New in Heterogeneous Connectivity User's Guide?

What's New in Heterogeneous Connectivity User's Guide?

This section describes new features of the Oracle Database 11g Release 2 (11.2) and provides pointers to additional information. New features information from previous releases is retained to help those users migrating to the current release.

The following sections describe the new features in Oracle Database Heterogeneous Connectivity User's Guide:

Oracle Database 11g Release 2 (11.2) New Features

New features for Oracle Database 11g Release 2 (11.2) in the Oracle Database Heterogeneous Connectivity User's Guide include:


See Also:

For additional information, consult the Oracle documentation for that specific gateway

Oracle Database 11g Release 1 (11.1) New Features

New features for Oracle Database 11g Release 1 (11.1) in the Oracle Database Heterogeneous Connectivity User's Guide include:

PKP PKr>AOEBPS/tgvsgc.htmML The Role of the Heterogeneous Services Component

2 The Role of the Heterogeneous Services Component

Oracle's synchronous solutions for operating in a heterogeneous environment are Oracle Database gateways. The common component of Oracle Database for supporting these solutions is Heterogeneous Services. This chapter describes the architecture and functionality of the Heterogeneous Services component and its interaction with Oracle Database gateways.

This chapter contains the following topics:

2.1 Heterogeneous Connectivity Process Architecture

At a high level, Oracle heterogeneous connectivity process architecture is structured as shown in Figure 2-1.

Figure 2-1 Oracle Heterogeneous Connectivity Process Architecture

Description of Figure 2-1 follows
Description of "Figure 2-1 Oracle Heterogeneous Connectivity Process Architecture"

The Heterogeneous Services component in Oracle Database communicates with a Heterogeneous Services agent process which, in turn, communicates with the non-Oracle system. The code can be conceptually divided into three parts:

2.2 Heterogeneous Services Agents

A Heterogeneous Services agent is the process through which Oracle Database connects to a non-Oracle system. The agent process that accesses a non-Oracle system is called a gateway. Access to all gateways goes through the Heterogeneous Services component in Oracle Database and all gateways contain the same agent-generic code. Each gateway has a different driver linked in that maps the Heterogeneous Services to the client API of the non-Oracle system.

The agent process consists of two components. These are agent generic code and a non-Oracle system-specific driver. An agent exists primarily to isolate Oracle Database from third-party code. For a process to access the non-Oracle system, the non-Oracle system client libraries must be linked into it. In the absence of the agent process, these libraries would have to be directly linked into the Oracle database and problems in this code could cause Oracle Database to fail. An agent process isolates Oracle Database from any problems in third-party code. Even if a fatal error occurs in the thirde-party code, only the agent process will end.

An agent can be in the following places:

Agent processes are started when a user session accesses a non-Oracle system through a database link. These connections are made using Oracle's remote data access software, Oracle Net Services, which enables both client/server and server/server communication. The agent process continues to run until the user session is disconnected or the database link is explicitly closed.

Multithreaded agents act differently. They must be explicitly started and shut down by a database administrator, instead of automatically being spawned by Oracle Net Services

2.3 Types of Heterogeneous Services Agents

There are two types of Heterogeneous Services agents:

2.3.1 Oracle Database Gateways

An Oracle Database gateway is a gateway that is designed for accessing a specific non-Oracle system. Oracle provides gateways to access several commercially available non-Oracle systems. For example, an Oracle Database Gateway for Sybase is designed to access Sybase databases.

With Oracle Database gateways, you can access data anywhere in a distributed database system without being required to know either the location of the data or how it is stored. When the results of your queries are returned to you by Oracle Database, they are presented to you as if the data stores from which they were taken all resided within a remote instance of an Oracle distributed database.

2.3.2 Oracle Database Gateway for ODBC Agent

In addition to Oracle Database gateways for various non-Oracle database systems, there is the Oracle Database Gateway for ODBC agent. This agent contains only generic code, and the customer is responsible for providing the necessary drivers. Oracle Database Gateway for ODBC enables you to use ODBC drivers to access non-Oracle systems that have an ODBC interface.

To access a specific non-Oracle system using Oracle Database Gateway for ODBC, you must configure an ODBC driver to the non-Oracle system. These drivers are not provided by Oracle. However, if the non-Oracle system supports the ODBC protocols, you can use Oracle Database Gateway for ODBC to access any non-Oracle system that can be accessed using an ODBC driver.

Oracle Database Gateway for ODBC has some limitations. Especially, when compared to a paticular target, the functionality and performance are limited.

2.4 Heterogeneous Services Components

This section discusses the components of Heterogeneous Services in Oracle Database. These components are:

2.4.1 Transaction Service

The transaction service component of the Heterogeneous Services component enables non-Oracle systems to be integrated into Oracle Database transactions and sessions. When you access a non-Oracle system for the first time using a database link within your Oracle user session, you transparently set up an authenticated session in the non-Oracle system. At the end of your Oracle user session, the authenticated session in the non-Oracle database system is closed.

Additionally, one or more non-Oracle systems can participate in an Oracle distributed transaction. When an application commits a transaction, Oracle's two-phase commit protocol accesses the non-Oracle database system to transparently coordinate the distributed transaction. Even in those cases where the non-Oracle system does not support all aspects of Oracle two-phase commit protocol, Oracle can (with some limitations) support distributed transactions with the non-Oracle system.

2.4.2 SQL Service

The structured query language (SQL) service handles the processing of all SQL-related operations. The work done by the SQL service includes:

  • Mapping Oracle internal SQL-related calls to the Heterogeneous Services driver application programing interface (API). This API is then mapped by the driver to the client API of the non-Oracle system.

  • Translating SQL statements from Oracle's SQL dialect to the SQL dialect of the non-Oracle system.

  • Translating queries that reference Oracle data dictionary tables to queries that extract the necessary information from the non-Oracle system's data dictionary.

  • Converting data from non-Oracle system data types to Oracle data types and back.

  • Compensating for missing functionality of the non-Oracle system by issuing multiple queries to get the necessary data and doing postprocessing to get the desired results.

2.5 Heterogeneous Services Configuration Information

Heterogeneous Services components consist of generic code and must be configured to work with many different non-Oracle systems. Each gateway has configuration information stored in the driver module. The information is uploaded to the server immediately after the connection to the gateway is established. The configuration information includes:

2.5.1 Data Dictionary Translation Views

Data dictionary translations are views on non-Oracle data dictionary tables. They help Heterogeneous Services translate references to Oracle data dictionary tables into queries that can retrieve the equivalent information from the non-Oracle data dictionary.

2.5.2 Heterogeneous Services Initialization Parameters

Heterogeneous Services initialization parameters serve two functions:

  • They give you a means of fine-tuning the gateway to optimize performance and memory utilization for the gateway and the Heterogeneous Services component.

  • They enable you to inform the gateway (and, thereby, Heterogeneous Services) how the non-Oracle system was configured (for example, in what language the non-Oracle system is running). They give information to Heterogeneous Services about the configurable properties of the non-Oracle system.

You can examine the Heterogeneous Services initialization parameters for a session by querying the view V$HS_PARAMETER. Users can set initialization parameters in gateway initialization files.

2.5.3 Capabilities

Capabilities tell Heterogeneous Services about the limitations of the non-Oracle system (such as what types of SQL statements are supported) and how to map Oracle data types and SQL expressions to their non-Oracle system equivalents. In other words, they tell Heterogeneous Services about the non-configurable properties of the non-Oracle system. Capabilities cannot be changed by the user.

2.6 The Heterogeneous Services Data Dictionary

Configuration information is uploaded from an agent to the Heterogeneous Services component immediately after the connection to the agent is established. The configuration information is stored in Heterogeneous Services data dictionary tables. No further uploading occurs until something at the agent changes (for example, if a patch is applied or if the agent is upgraded to a new version).

The following sections describe:

2.6.1 Classes and Instances

Using Heterogeneous Services, you can access several non-Oracle systems from a single Oracle database. This is illustrated in Figure 2-2, which shows two non-Oracle systems being accessed.

Figure 2-2 Accessing Multiple Non-Oracle Instances

Description of Figure 2-2 follows
Description of "Figure 2-2 Accessing Multiple Non-Oracle Instances"

Both agents upload configuration information, which is stored as part of the Heterogeneous Services data dictionary information on Oracle Database.

Although it is possible to store data dictionary information at one level of granularity by having completely separate definitions in the Heterogeneous Services data dictionary for each individual instance, this can lead to an unnecessarily large amount of redundant data dictionary information. To avoid this, Oracle organizes the Heterogeneous Services data dictionary by two levels of granularity, called class and instance.

A class pertains to a specific type of non-Oracle system. For example, you may want to access the class of Sybase database systems with Oracle Database. An instance defines specializations within a class. For example, you may want to access several separate instances within a Sybase database system. Each class definition (one level of granularity) is shared by all the particular instances (a second level of granularity) under that class. Further, instance information takes precedence over class information, and class information takes precedence over server-supplied defaults.

For example, suppose that Oracle Database accesses three instances of Sybase and two instances of Ingres II. Sybase and Ingres II each have their own code, requiring separate class definitions for Oracle Database to access them. The Heterogeneous Services data dictionary therefore would contain two class definitions, one for Sybase and one for Ingres II, with five instance definitions, one for each instance being accessed by Oracle Database.

Note that instance-level capability and data dictionary information are session-specific and are not stored in the Heterogeneous Services data dictionary of Oracle Database. However, instance-level initialization parameters can be stored in the database.

2.6.2 Data Dictionary Views

The Heterogeneous Services data dictionary views contain the following kinds of information:

  • Names of instances and classes uploaded into the Oracle data dictionary

  • Capabilities, including SQL translations, defined for each class or instance

  • Data Dictionary translations defined for each class or instance

  • Initialization parameters defined for each class or instance

You can access information from the Oracle data dictionary by using fixed views. The views are categorized into three main types:

  • General views

  • Views used for the transaction service

  • Views used for the SQL service

2.7 Gateway Process Flow

Figure 2-3 shows a typical gateway process flow. The steps explain the sequence of events that occur when a client application queries the non-Oracle database system database through the gateway.

Figure 2-3 Gateway Process Flow

Description of Figure 2-3 follows
Description of "Figure 2-3 Gateway Process Flow"

  1. The client application sends a query using Oracle Net to Oracle Database.

  2. Heterogeneous Services and the gateway converts the SQL statement into a SQL statement understood by the non-Oracle database system.

  3. Oracle Database sends the query to the gateway using Oracle Net.

  4. For the first transaction in a session, the gateway logs in to non-Oracle database system using a user name and password that is valid in the non-Oracle system.

  5. The gateway retrieves data using non-Oracle database system SQL statements.

  6. The gateway converts retrieved data into a format compatible with Oracle Database.

  7. The gateway returns query results to Oracle Database, again using Oracle Net Services.

  8. Oracle Database passes the query results to the client application using Oracle Net. The database link remains open until the gateway session is finished, or the database link is explicitly closed.

PK0?MMPKr>AOEBPS/title.htm  Oracle Database Heterogeneous Connectivity User's Guide, 11g Release 2 (11.2)

Oracle® Database

Heterogeneous Connectivity User's Guide

11g Release 2 (11.2)

E11050-01

July 2009


Oracle Database Heterogeneous Connectivity User's Guide, 11g Release 2 (11.2)

E11050-01

Copyright © 2001, 2009, Oracle and/or its affiliates. All rights reserved.

This software and related documentation are provided under a license agreement containing restrictions on use and disclosure and are protected by intellectual property laws. Except as expressly permitted in your license agreement or allowed by law, you may not use, copy, reproduce, translate, broadcast, modify, license, transmit, distribute, exhibit, perform, publish, or display any part, in any form, or by any means. Reverse engineering, disassembly, or decompilation of this software, unless required by law for interoperability, is prohibited.

The information contained herein is subject to change without notice and is not warranted to be error-free. If you find any errors, please report them to us in writing.

If this software or related documentation is delivered to the U.S. Government or anyone licensing it on behalf of the U.S. Government, the following notice is applicable:

U.S. GOVERNMENT RIGHTS Programs, software, databases, and related documentation and technical data delivered to U.S. Government customers are "commercial computer software" or "commercial technical data" pursuant to the applicable Federal Acquisition Regulation and agency-specific supplemental regulations. As such, the use, duplication, disclosure, modification, and adaptation shall be subject to the restrictions and license terms set forth in the applicable Government contract, and, to the extent applicable by the terms of the Government contract, the additional rights set forth in FAR 52.227-19, Commercial Computer Software License (December 2007). Oracle USA, Inc., 500 Oracle Parkway, Redwood City, CA 94065.

This software is developed for general use in a variety of information management applications. It is not developed or intended for use in any inherently dangerous applications, including applications which may create a risk of personal injury. If you use this software in dangerous applications, then you shall be responsible to take all appropriate fail-safe, backup, redundancy, and other measures to ensure the safe use of this software. Oracle Corporation and its affiliates disclaim any liability for any damages caused by use of this software in dangerous applications.

Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners.

This software and documentation may provide access to or information on content, products, and services from third parties. Oracle Corporation and its affiliates are not responsible for and expressly disclaim all warranties of any kind with respect to third-party content, products, and services. Oracle Corporation and its affiliates will not be responsible for any loss, costs, or damages incurred due to your access to or use of third-party content, products, or services.

PK% PKr>AOEBPS/intro.htm38 Introduction

1 Introduction

This chapter describes the challenges of operating in a heterogeneous environment. Oracle recognizes these challenges and offers both synchronous and asynchronous solutions that enable companies to easily operate in such an environment. The synchronous solution, Oracle Database gateway, is discussed in this guide.

This chapter contains the following topics:

1.1 The Information Integration Challenge

Information integration is a challenge that affects many organizations because they may run several different database systems. Each of these systems store data and has a set of applications that run against the data. This data is just bits and bytes on a file system - and only a database can turn the bits and bytes of data into business information. Integration and consolidation of all business information allows an organization to take advantage of the synergies inherent in business information.

Consolidation of all data into one database system is often difficult. This is primarily because many of the applications that run against one database may not have an equivalent application that runs against another. Until migrating data to one consolidated database system is possible, the heterogeneous database systems must work together.

There are several problems to overcome before interoperability is possible. The database systems can be accessed using different interfaces, different data types, different capabilities, and different ways of handling errors. Even when one relational database tries to access another relational database, the differences are significant. In this situation, the common features of the databases include data access through SQL, two-phase commit protocol, and similar data types.

There are also significant differences. SQL dialects can be different, as can transaction semantics. There can be some data types in one database that do not exist in the other. The most significant area of difference is in the data dictionaries of the two databases. Most data dictionaries contain similar information, but the information is structured for each data dictionary in a different way. There are several ways of overcoming this problem. This guide describes Oracle's approach to synchronously access information from multiple sources.

1.2 How Oracle Addresses Synchronous Information Integration

If a client program must access or modify data on several Oracle databases, it can open connections to each of them. This approach, however, has several drawbacks; among them are the following:

Oracle provides another approach called distributed processing, where the client connects to one Oracle database and shifts the burden of joining data and transaction coordination to that database. The database to which the client program connects is called the local database. Any database other than this one is a remote database. The client program can access objects at any of the remote databases using database links. The Oracle query processor takes care of the joins and its transaction engine takes care of the transaction coordination.

The approach that Oracle took to solve the heterogeneous connectivity problem is to allow a non-Oracle system to be one of the remote nodes in the previously described scenario. The remote non-Oracle system functions as a remote Oracle system. The non-Oracle system uses the same SQL dialect and the same data dictionary structure as an Oracle system. Access to a non-Oracle system is done through Heterogeneous Services.

The work done by the Heterogeneous Services component is, for the most part, completely transparent to the end user. With only a few exceptions (these are noted in later chapters), you are not required to do anything different to access a non-Oracle system than is required for accessing an Oracle system. The Heterogeneous Services component is used as the foundation for implementing Oracle's access to non-Oracle databases.

An Oracle Database gateway works in conjunction with the Heterogeneous Services component of Oracle Database to access a particular, commercially available, non-Oracle system for which that Oracle Database gateway was designed. For example, you use the Oracle Database Gateway for Sybase to access a Sybase database. Oracle also provides an Oracle Database Gateway for ODBC which enables you to use ODBC drivers to access non-Oracle databases.

Using an Oracle Database gateway, you can access data anywhere in a distributed database system without being required to know either the location of the data or how it is stored.


Note:

The ODBC drivers that are required by Oracle Database Gateway for ODBC are not supplied by Oracle. Users must obtain drivers from other vendors.

Oracle also offers asynchronous information integration products. Those products are not discussed in this guide. Briefly, these products include:

1.3 Benefits of Oracle's Solution for Synchronous Information Integration

Much of the processing power of Oracle Database gateways is integrated into the database. This provides an efficient solution for information integration that enables full exploitation of the power and features of the Oracle database. This includes such features as powerful SQL parsing and distributed optimization capabilities.

The following sections describe the benefits of Oracle's approach to resolving the challenges of a heterogeneous environment:

1.3.1 Remote Data Can Be Accessed Transparently

Oracle Database gateways provide the ability to transparently access data in non-Oracle databases from an Oracle environment. You can create synonyms for the objects in a non-Oracle database and refer to them without having to specify a physical location. This transparency eliminates the need for application developers to customize their applications to access data from different non-Oracle systems, thus decreasing development efforts and increasing the mobility of the application.

Instead of requiring applications to interoperate with non-Oracle systems using their native interfaces (which can result in intensive application-side processing), applications can be built upon a consistent Oracle interface for both Oracle and non-Oracle systems.

1.3.2 No Unnecessary Data Duplication

Oracle Database gateways provide applications direct access to data in non-Oracle databases. This eliminates the need to upload and download large amounts of data to different locations, thus reducing data duplication and saving disk storage space. By eliminating uploading and downloading large amounts of data, there is a reduced risk for unsynchronized or inconsistent data.

1.3.3 SQL Statements Can Query Several Different Databases

An Oracle database accepts SQL statements that query data stored in several different databases. An Oracle database with the Heterogeneous Services component processes the SQL statement and passes the appropriate SQL code directly to other Oracle databases and through gateways to non-Oracle databases. The Oracle database combines the results and returns them to the client.

1.3.4 Oracle's Application Development and End User Tools Can Be Used

Oracle Database gateways extend the range of Oracle's database and application development tools. Oracle has tools that increase application development and user productivity by reducing prototype, development, and maintenance time.

You are not required to develop new tools or learn how to use other tools to access data stored in non-Oracle databases. Instead, you can access Oracle and non-Oracle data with a single set of Oracle tools. These tools can run on remote systems connected through Oracle Net to an Oracle database.

1.3.5 Users Can Communicate With a Remote Database in its Own Language

Oracle enables you to transparently access non-Oracle systems using SQL statements. In some cases, however, it becomes necessary to use non-Oracle system SQL to access the non-Oracle system. For such cases, Heterogeneous Services has a passthrough feature that enables you to bypass Oracle's query processor and to communicate with the remote database in its own language.

PK A33PKr>AOEBPS/admin.htm Using Heterogeneous Services Agents

4 Using Heterogeneous Services Agents

This chapter explains how to use Heterogeneous Services (HS) agents. For installing and configuring the agents, refer to the Oracle Database gateway installation and configuration guides. This chapter contains the following sections:

4.1 Initialization Parameters

Configure the gateway using initialization parameters. This is done by creating an initialization file and setting the desired parameters in this file. See Section 2.5 for configuration information.

Heterogeneous Services initialization parameters are distinct from Oracle Database initialization parameters. Heterogeneous Services initialization parameters are set in the Heterogeneous Services initialization file and not in the Oracle database initialization parameter file (init.ora file). There is a Heterogeneous Services initialization file for each gateway instance.

The following sections describe:

4.1.1 Encrypting Initialization Parameters

Initialization parameters may contain sensitive information, such as user IDs or passwords. Initialization parameters are stored in plain text files and are insecure. An encryption feature has been added to Heterogeneous Services making it possible to encrypt parameter values. This is done through the dg4pwd utility. To use this feature requires setting the value of a parameter in the initialization file to an unquoted asterisk (*). For example:

HD_FDS_CONNECT_INFO = *

With the value set to this security marker, all Heterogeneous Services agents know that the real value will be stored in a related, encrypted password file. The name of this file will be initsid.pwd, where sid is the Oracle system identifier used for the gateway. This file is created by the dg4pwd utility in the current directory containing the initialization file. Running the utility prompts for the real value of the parameter, which the utility will encrypt and store in the password file. It should be noted that encrypted initialization parameters are implicitly treated as PRIVATE parameters and are not uploaded to the server.

4.1.1.1 Using the dg4pwd Utility

The dg4pwd utility is used to encrypt initialization parameters that would normally be stored in the initialization parameter file in plain text. The utility works by reading the initialization parameter file in the current directory and looking for parameters having a security marker for the value. The security marker is an unquoted asterisk (*). This designates that the value of this parameter is to be stored in an encrypted form in a password file. The following is an example of an initialization parameter set to this value:

HS_FDS_CONNECT_INFO = *

The initialization parameter file in the current directory is first edited to set the value of the parameter to this security marker. Then the utility is run, specifying the gateway SID on the command line, with an optional user ID to designate a different owner of the encrypted information. The utility reads the initialization parameter file and prompts you to enter the real values that are to be encrypted. The syntax of the command is:

dg4pwd [sid] {userid}

Where [sid] is the SID of the gateway and {userid} is an optional user ID used to encrypt the contents. If no user ID is specified, then the current user's ID is used. Values are encrypted using this ID. In order to decrypt the values, the agent must be run as that user. The following example assumes a gateway SID of SYBASE:

dg4pwd SYBASE
ORACLE Gateway Password Utility
Constructing password file for Gateway SID SYBASE
Enter the value for HS_FDS_CONNECT_INFO
sybasew

In the previous example, the initialization parameter file, initSYBASE.ora, is read. The parameter, HS_FDS_CONNECT_INFO, is identified as requiring encryption. Enter the value (for example, sybasew) and presses enter. If more parameters require encryption, they are prompted for in turn. The encrypted data is stored in the same directory as the initialization file.Any initialization parameters needing encryption should be encrypted before using the Oracle Database gateway.

4.1.2 Gateway Initialization Parameters

Gateway initialization parameters can be divided into two groups. One is a set of generic initialization parameters that are common to all gateways and the other is a set of initialization parameters that are specific to individual gateways. The following generic initialization parameters are the only initialization parameters discussed in this document:


HS_BULK
HS_CALL_NAME
HS_COMMIT_POINT_STRENGTH
HS_DB_DOMAIN
HS_DB_INTERNAL_NAME
HS_DB_NAME
HS_DESCRIBE_CACHE_HWM
HS_FDS_CONNECT_INFO
HS_FDS_DEFAULT_SCHEMA_NAME
HS_FDS_SHAREABLE_NAME
HS_FDS_TRACE_LEVEL
HS_LANGUAGE
HS_LONG_PIECE_TRANSFER_SIZE
HS_NLS_DATE_FORMAT
HS_NLS_DATE_LANGUAGE
HS_NLS_NCHAR
HS_NLS_NUMERIC_CHARACTERS
HS_NLS_TIMESTAMP_FORMAT
HS_NLS_TIMESTAMP_TZ_FORMAT
HS_OPEN_CURSORS
HS_ROWID_CACHE_SIZE
HS_RPC_FETCH_REBLOCKING
HS_RPC_FETCH_SIZE
HS_TIME_ZONE

Do not use the PRIVATE keyword when setting any of these parameters. Using the PRIVATE keyword prevents the parameter from being uploaded to the server and can cause errors in SQL processing. None of these parameters needs to be set in the environment, so you do not need to use the SET keyword.


See Also:

Individual gateway documentation for the list of initialization parameters specific to a gateway

4.2 Optimizing Data Transfers Using Bulk Fetch

When an application fetches data from a non-Oracle system using Heterogeneous Services, data is transferred:

  1. From the non-Oracle system to the agent process.

  2. From the agent process to Oracle Database.

  3. From Oracle Database to the application.

Oracle optimizes all three data transfers, as illustrated in Figure 4-1.

Figure 4-1 Optimizing Data Transfers

Description of Figure 4-1 follows
Description of "Figure 4-1 Optimizing Data Transfers"

This section contains the following topics:

4.2.1 Using OCI, an Oracle Precompiler, or Another Tool for Array Fetches

You can optimize data transfers between your application and Oracle Database by using array fetches. See your application development tool documentation for information about array fetching and how to specify the amount of data to be sent and each network round-trip.

4.2.2 Controlling the Array Fetch Between Oracle Database and the Agent

When Oracle retrieves data from a non-Oracle system, the Heterogeneous Services initialization parameter, HS_RPC_FETCH_SIZE, defines the number of bytes sent for each fetch between the agent and Oracle Database. The agent fetches data from the non-Oracle system until one of the following occurs:

  • It has accumulated the specified number of bytes to send back to Oracle Database.

  • The last row of the result set is fetched from the non-Oracle system.

4.2.3 Controlling the Array Fetch Between the Agent and the Non-Oracle System

The initialization parameter, HS_FDS_FETCH_ROWS, determines the number of rows to be retrieved from a non-Oracle system. Note that the array fetch must be supported by the agent. See your agent-specific documentation to ensure that your agent supports array fetching.

4.2.4 Controlling the Reblocking of Array Fetches

By default, an agent fetches data from the non-Oracle system until it has enough data retrieved to send back to the system. It continues until the number of bytes fetched from the non-Oracle system is equal to or higher than the value of HS_RPC_FETCH_SIZE initialization parameter. In other words, the agent reblocks the data between the agent and Oracle Database in sizes defined by the value of the HS_RPC_FETCH_SIZE initialization parameter.

When the non-Oracle system supports array fetches, you can immediately send the data fetched from the non-Oracle system by the array fetch to Oracle Database without waiting until the exact value of the HS_RPC_FETCH_SIZE initialization parameter is reached. That is, you can stream the data from the non-Oracle system to Oracle Database and disable reblocking by setting the value of the HS_RPC_FETCH_REBLOCKING initialization parameter to OFF.

For example, assume that you set HS_RPC_FETCH_SIZE to 64 kilobytes (KB) and HS_FDS_FETCH_ROWS to 100 rows. Also assume that each row is approximately 600 bytes in size, so that the 100 rows are approximately 60 KB. When the HS_RPC_FETCH_REBLOCKING initialization parameter is set to ON, the agent starts fetching 100 rows from the non-Oracle system.

Because there is only 60 KB of data in the agent, the agent does not send the data back to Oracle Database. Instead, the agent fetches the next 100 rows from the non-Oracle system. Because there is now 120 KB of data in the agent, the first 64 KB can be sent back to Oracle Database.

Now there is 56 KB of data left in the agent. The agent fetches another 100 rows from the non-Oracle system before sending the next 64 KB of data to Oracle Database. By setting the HS_RPC_FETCH_REBLOCKING initialization parameter to OFF, the first 100 rows are immediately sent back to the Oracle database server.

4.3 Optimizing Data Loads Using Parallel Load

The DBMS_HS_PARALLEL PL/SQL package enables parallel processing for heterogeneous targets access. This package improves performance when retrieving data from a large foreign table.

DBMS_HS_PARALLEL is compiled with an authorization ID of CURRENT_USER, meaning it uses invoker's rights. In other words, all procedures in this package are executed with the privileges of the calling user.

For additional information about the procedures, see Oracle Database PL/SQL Packages and Types Reference.

4.4 Registering Agents

Registration is an operation through which Oracle stores information about an agent in the data dictionary. Agents do not have to be registered. If an agent is not registered, Oracle stores information about the agent in memory instead of in the data dictionary. When a session involving an agent terminates, this information ceases to be available.

Self-registration is an operation in which a database administrator sets an initialization parameter that lets the agent automatically upload information into the data dictionary. Self-registration occurs when the HS_AUTOREGISTER initialization parameter is set to TRUE (default).


Note:

HS_AUTOREGISTER is an Oracle initialization parameter that you set in the init.ora file; it is not a Heterogeneous Services initialization parameter that is set in the gateway initialization file.

This section contains the following topics:

4.4.1 Enabling Agent Self-Registration

To ensure correct operation over heterogeneous database links, agent self-registration automates updates to Heterogeneous Services configuration data that describe agents on remote hosts. Agent self-registration is the default behavior. If you do not want to use the agent self-registration feature, set the HS_AUTOREGISTER initialization parameter to FALSE.

Both the server and the agent rely on three types of information to configure and control operation of the Heterogeneous Services connection. These three sets of information are collectively called HS configuration data:

Heterogeneous Services Configuration DataDescription
Heterogeneous Services initialization parametersProvide control over various connection-specific details of operation.
Capability definitionsIdentify details like SQL language features supported by the non-Oracle data source.
Data dictionary translationsMap references to Oracle data dictionary tables and views into equivalents specific to the non-Oracle data source.

4.4.1.1 Using Agent Self-Registration to Avoid Configuration Mismatches

HS configuration data is stored in the data dictionary of the Oracle database server. Because the agent may be remote and may therefore be administered separately, several circumstances can lead to configuration mismatches between servers and agents. For example:

  • An agent can be newly installed on a separate computer so that the server has no Heterogeneous Services data dictionary content to represent the agent's Heterogeneous Services configuration data.

  • A server can be newly installed and lack the necessary Heterogeneous Services configuration data for existing agents and non-Oracle data stores.

  • A non-Oracle instance can be upgraded from an older version to a newer version, requiring modification of the Heterogeneous Services configuration data.

  • A Heterogeneous Services agent at a remote site can be upgraded to a new version or patched, requiring modification of the Heterogeneous Services configuration data.

  • A database administrator (DBA) at the non-Oracle site can change the agent setup, possibly for tuning or testing purposes, in a manner which affects Heterogeneous Services configuration data.

Agent self-registration permits successful operation of Heterogeneous Services in all these scenarios. Specifically, agent self-registration enhances interoperability between any Oracle database server and any Heterogeneous Services agent (if each is Version 8.0.3 or higher). The basic mechanism for this functionality is the ability to upload Heterogeneous Services configuration data from agents to servers.

Self-registration provides automatic updating of Heterogeneous Services configuration data residing in the Oracle database server data dictionary. This update ensures that the agent self-registration uploads need to be done only once, on the initial use of a previously unregistered agent. Instance information is uploaded on each connection, not stored in the server data dictionary.

4.4.1.2 Understanding Agent Self-Registration

The Heterogeneous Services agent self-registration feature can perform the following tasks:

  • Identify the agent and the non-Oracle data store to the Oracle database server

  • Permit agents to define Heterogeneous Services initialization parameters for use both by the agent and connected Oracle servers

  • Upload capability definitions and data dictionary translations, if available, from a Heterogeneous Services agent during connection initialization


    Note:

    The upload of class information occurs only when the class is undefined in the server data dictionary. Similarly, instance information is uploaded only if the instance is undefined in the server data dictionary.

The information required for agent self-registration is accessed in the server data dictionary by using these agent-supplied names:

4.4.1.2.1 FDS_CLASS and FDS_CLASS_VERSION

FDS_CLASS and FDS_CLASS_VERSION are defined by Oracle or by third-party vendors for each individual Heterogeneous Services agent and version. Oracle Heterogeneous Services concatenates these names to form FDS_CLASS_NAME, which is used as a primary key to access class information in the server data dictionary.

FDS_CLASS should specify the type of non-Oracle data store to be accessed and FDS_CLASS_VERSION should specify a version number for both the non-Oracle data store and the agent that connects to it. Note that when any component of an agent changes, FDS_CLASS_VERSION must also change to uniquely identify the new release.


Note:

This information is uploaded when you initialize each connection.

4.4.1.2.2 FDS_INST_NAME

Instance-Specific Information can be stored in the server data dictionary. The instance name, FDS_INST_NAME, is configured by the database administrator (DBA) who administers the agent. How the DBA performs this configuration depends on the specific agent in use.

The Oracle database server uses FDS_INST_NAME to look up instance-specific configuration information in its data dictionary. Oracle uses the value as a primary key for columns of the same name in these views:

  • FDS_INST_INIT

  • FDS_INST_CAPS

  • FDS_INST_DD

Server data dictionary accesses that use FDS_INST_NAME also use FDS_CLASS_NAME to uniquely identify configuration information rows. For example, if you port a database from class Sybase816 to class Sybase817, both databases can simultaneously operate with instance name SCOTT and use separate sets of configuration information.

Unlike class information, instance information is not automatically self-registered in the server data dictionary:

  • If available, instance information is always uploaded by the agent. However, it is never stored in the server data dictionary. Instead, the information is kept in memory and it is only valid for that connection.

  • If the server data dictionary contains instance information, it represents the DBA's defined setup details which correspond to the instance configuration. Data dictionary defined instance information takes precedence over class information. However, uploaded instance information takes precedence over data dictionary defined instance information.

4.4.1.3 Specifying HS_AUTOREGISTER

The HS_AUTOREGISTER Oracle database server initialization parameter enables or disables automatic self-registration of Heterogeneous Services agents. Note that this parameter is specified in the Oracle initialization parameter file, not the agent initialization file. For example, you can set the parameter as follows:

HS_AUTOREGISTER = TRUE

When set to TRUE, the agent uploads information describing a previously unknown agent class or a new agent version into the server's data dictionary.

Oracle recommends that you use the default value for this parameter (TRUE), which ensures that the server's data dictionary content always correctly represents definitions of class capabilities and data dictionary translations as used in Heterogeneous Services connections.


See Also:

Oracle Database Reference for a description of this parameter

4.4.2 Disabling Agent Self-Registration

To disable agent self-registration, set the HS_AUTOREGISTER initialization parameter as follows:

HS_AUTOREGISTER = FALSE

Disabling agent self-registration means that agent information is not stored in the data dictionary. Consequently, the Heterogeneous Services data dictionary views are not useful sources of information. Nevertheless, the Oracle server still requires information about the class and instance of each agent. If agent self-registration is disabled, the server stores this information in local memory.

4.5 Oracle Database Server SQL Construct Processing

Heterogeneous Services and the gateway rewrite SQL statements when the statements need to be translated or postprocessed.

For the following examples, assume the INITCAP function is not supported in the non-Oracle database. Consider a program that requests the following from the non-Oracle database. For example:

SELECT "COLUMN_A" FROM "test"@remote_db
    WHERE "COLUMN_A" = INITCAP("COLUMN_B");

The non-Oracle database does not recognize the INITCAP function, so the Oracle database server fetches the data from the table test in the remote database and filters the results locally. The gateway rewrites the SELECT statement as follows:

SELECT "COLUMN_A", "COLUMN_B" FROM "test"@remote_db;

The results of the query are sent from the gateway to Oracle and are filtered by the Oracle database server.

If a string literal or bind variable is supplied in place of "COLUMN_B" as shown in the previous example, the Heterogeneous Services component of the Oracle server would apply the INITCAP function before sending the SQL command to the gateway. For example, if the following SQL command is issued:

SELECT "COLUMN_A" FROM "test"@remote_db WHERE "COLUMN_A" = INITCAP('jones');

The following SQL command would be sent to the gateway:

SELECT "COLUMN_A" FROM "test"@remote_db WHERE "COLUMN_A" = 'Jones';

Consider the following UPDATE request:

UPDATE "test"@remote_db SET "COLUMN_A" = 'new_value'
    WHERE "COLUMN_A" = INITCAP("COLUMN_B");

In this case, the Oracle database server and the gateway cannot compensate for the lack of support at the non-Oracle side, so an error is issued.

If a string literal or bind variable is supplied in place of "COLUMN_B" as shown in the preceding example, the Heterogeneous Services component of the Oracle server would apply the INITCAP function before sending the SQL command to the gateway. For example, if the following SQL command is issued:

UPDATE "test"@remote_db SET "COLUMN_A" = 'new_value' 
    WHERE "COLUMN_A" = INITCAP('jones');

The following SQL command would be sent to the gateway:

UPDATE  "test"@remote_db SET "COLUMN_A" = 'new_value' 
    WHERE "COLUMN_A" = 'Jones';

In previous releases, the preceding UPDATE statement would have raised an error due to the lack of INITCAP function support in the non-Oracle database.

4.5.1 Data Type Checking Support for a Remote-Mapped Statement

The Oracle database has always performed data type checking and data type coercion in a homogeneous environment. For example, SELECT * FROM EMP WHERE EMPNO='7934' would return the same result as SELECT * FROM EMPNO WHERE EMPNO=7934. There is also full data type checking support for remote-mapped statements in a heterogeneous environment. In general, the operands in SQL statements whether its a column, literal, or bind variable would be processed internally for data type checking. Consider the following examples:

SELECT * FROM EMP@LINK WHERE NUMBER_COLUMN='123'
SELECT * FROM EMP@LINK WHERE NUMBER_COLUMN=CHAR_COLUMN;
SELECT * FROM EMP@LINK WHERE NUMBER_COLUMN=CHAR_BIND_VARIABLE;

Most non-Oracle databases do not support data type coercion, and the previous statements fail if they are sent to a non-Oracle database as is. The Heterogeneous Services component for the Oracle database performs data type checking and the necessary data type coercion before sending an acceptable statement to a non-Oracle database.

Data type checking provides consistent behavior on post-processed or remote-mapped statements. Consider the following two statements:

SELECT * FROM EMP@LINK WHERE TO_CHAR(EMPNO)='7933' + '1';

And:

SELECT * FROM EMP@LINK WHERE EMPNO='7933' + '1';

Both of the previous statements provide the same result and coercion regardless if the TO_CHAR function is supported in the non-Oracle database or not. Now, consider the following statement:

SELECT * FROM EMP@LINK WHERE EMPNO='123abc' + '1';

As data type checking is enforced, the coercion attempt within Oracle generates an error and returns it without sending any statements to a non-Oracle database.

In summary, there is consistent data type checking and coercion behavior regardless of post-processed or remote-mapped statements.

4.6 Executing User-Defined Functions on a Non-Oracle Database

You can execute user-defined functions in a remote non-Oracle database. For example:

SELECT getdeptforemp@Remote_DB(7782) FROM dual;

In this example, a SELECT statement was issued that executes a user-defined function in the remote database that returns department information for employee 7782.

When the remote function resides in an Oracle database, the Oracle database automatically ensures that the remote function does not update any database state (such as updating rows in a database or updating the PL/SQL package state). The gateway cannot verify this when the remote function resides in a non-Oracle database. Therefore, you are responsible for ensuring that the user-defined functions do not update the state in any database. Ensuring no updates to the database is required to guarantee read consistency.

As a security measure, you must specify the functions that you want to execute remotely and their owners in the HS_CALL_NAME parameter in the gateway-specific initialization parameter file. For example:


HS_CALL_NAME = "owner1.A1, owner2.A2 "

owner1 and owner2 are the remote function owner names. A1 and A2 are the remote function names. You do not need to specify the remote function owner in the SQL statement. By default, the remote function needs to reside in the schema that the Database Gateway connects to. If this is not the case, then you must specify the owner of the remote function in the SQL statement.

Some other examples of executing user-defined remote functions are as follows:

In these examples, the Oracle database passes the function name and owner to the Database Gateway. The user-defined function is executed on the remote database.

4.7 Using Synonyms

You can provide complete data location transparency and network transparency by using the synonym feature of the Oracle database server. When a synonym is defined, you do not have to know the underlying table or network protocol. A synonym can be public, which means that all Oracle users can refer to the synonym. A synonym can also be defined as private, which means every Oracle user must have a synonym defined to access the non-Oracle table.

The following statement creates a systemwide synonym for the emp table in the schema of user ORACLE in the Sybase database:

CREATE PUBLIC SYNONYM emp FOR "ORACLE"."EMP"@SYBS;


See Also:

Oracle Database Administrator's Guide for information about synonyms


4.7.1 Example of a Distributed Query


Note:

Modify these examples for your environment. Do not try to execute them as they are written.

The following statement joins data between the Oracle database server, an IBM DB2 database, and a Sybase database:

SELECT O.CUSTNAME, P.PROJNO, E.ENAME, SUM(E.RATE*P."HOURS")
       FROM ORDERS@DB2 O, EMP@ORACLE9 E, "PROJECTS"@SYBS P
       WHERE O.PROJNO = P."PROJNO"
          AND P."EMPNO" = E.EMPNO
       GROUP BY O.CUSTNAME, P."PROJNO", E.ENAME;

Through a combination of views and synonyms, using the following SQL statements, the process of distributed queries is transparent:

CREATE SYNONYM ORDERS FOR ORDERS@DB2;
CREATE SYNONYM PROJECTS FOR "PROJECTS"@SYBS;
CREATE VIEW DETAILS (CUSTNAME,PROJNO,ENAME,SPEND)
      AS 
      SELECT O.CUSTNAME, P."PROJNO", E.ENAME, SUM(E.RATE*P."HOURS")
      SPEND
      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;

Use the following SQL statement to retrieve information from the data stores in one statement:

SELECT * FROM DETAILS;

The statement retrieves the following table:

CUSTNAME         PROJNO           ENAME          SPEND
--------         ------           -----          -----
ABC Co.             1             Jones            400
ABC Co.             1             Smith            180
XYZ Inc.            2             Jones            400
XYZ Inc.            2             Smith            180


4.8 Copying Data from the Oracle Database Server to the Non-Oracle Database System

Heterogeneous Services supports callback links. This enables SQL statements like the following to be executed:

INSERT INTO table_name@dblink SELECT column_list FROM table_name;

Even though Heterogeneous Services supports the callback functionality, not all gateways have implemented it. If the gateway that you are using has not implemented this functionality, the preceding INSERT statement returns the following error message:

ORA-02025: All tables in the SQL statement must be at the remote database

See Also:

Your gateway documentation for information about support for callback links

For gateways that do not support callback links, you can use the SQL*Plus COPY command. The syntax is as follows:

COPY FROM username/password@db_name -
   INSERT destination_table -
   USING query;

The following example selects all rows from the local Oracle emp table, inserts them into the emp table on the non-Oracle database, and commits the transaction:

COPY FROM SCOTT/TIGER@inst1 -
  INSERT EMP@remote_db -
  USING SELECT * FROM EMP;



The COPY command supports the APPEND, CREATE, INSERT, and REPLACE options. However, INSERT is the only option supported when copying to non-Oracle databases. The SQL*Plus COPY command does not support copying to tables with lowercase table names. Use the following PL/SQL syntax with lowercase table names: DECLARE v1 oracle_table.column1%TYPE; v2 oracle_table.column2%TYPE; v3 oracle_table.column3%TYPE; . . . CURSOR cursor_name IS SELECT * FROM oracle_table; BEGIN OPEN cursor_name; LOOP FETCH cursor_name INTO v1, v2, v3, ... ; EXIT WHEN cursor_name%NOTFOUND; INSERT INTO destination_table VALUES (v1, v2, v3, ...); END LOOP; CLOSE cursor_name; END;

See Also:

SQL*Plus User's Guide and Reference for more information about the COPY command

4.9 Copying Data from the Non-Oracle Database System to the Oracle Database Server

The CREATE TABLE statement lets you copy data from a non-Oracle database to the Oracle database. To create a table on the local database and insert rows from the non-Oracle table, use the following syntax:

CREATE TABLE table_name AS query;

The following example creates the table emp in the local Oracle database and inserts the rows from the EMP table of the non-Oracle database:

CREATE TABLE table1 AS SELECT * FROM "EMP"@remote_db;



Alternatively, you can use the SQL*Plus COPY command to copy data from the non-Oracle database to the Oracle database server.

See Also:

SQL*Plus User's Guide and Reference for more information about the COPY command


4.10 Using Heterogeneous Services Data Dictionary Views

You can use the Heterogeneous Services data dictionary views to access information about Heterogeneous Services. This section addresses the following topics:

4.10.1 Understanding the Types of Views

The Heterogeneous Services data dictionary views, whose names all begin with the HS_ prefix, can be divided into the following categories:

  • General views

  • Views used for the transaction service

  • Views used for the SQL service

Most of the data dictionary views are defined for both classes and instances. For most types of data there is a *_CLASS view and a *_INST view. See Table 4-1 for additional details.

Table 4-1 Data Dictionary Views for Heterogeneous Services

ViewTypeIdentifies

HS_BASE_CAPS

SQL service

All capabilities supported by Heterogeneous Services

HS_BASE_DD

SQL service

All data dictionary translation table names supported by Heterogeneous Services

HS_CLASS_CAPS

Transaction service, SQL service

Capabilities for each class

HS_CLASS_DD

SQL service

Data dictionary translations for each class

HS_CLASS_INIT

General

Initialization parameters for each class

HS_FDS_CLASS

General

Classes accessible from the Oracle server

HS_FDS_INST

General

Instances accessible from the Oracle server

HS_INST_CAPS

Transaction service, SQL service

Capabilities for each instance (if set up by the DBA)

HS_INST_DD

SQL service

Data dictionary translations for each class (if set up by the DBA)

HS_INST_INIT

General

Initialization parameters for each instance (if set up by the DBA)

HS_BULK


Data dictionary view to keep track of internal objects created with bulk load procedures.


Like all Oracle data dictionary tables, these views are read-only. Do not change the content of any of the underlying tables.

4.10.2 Understanding the Sources of Data Dictionary Information

The values used for data dictionary content in any particular connection on a Heterogeneous Services database link can come from any of the following sources, in order of precedence:

  • Instance information uploaded by the connected Heterogeneous Services agent at the start of the session. This information overrides corresponding content in the Oracle data dictionary, but is never stored into the Oracle data dictionary.

  • Instance information stored in the Oracle data dictionary. This data overrides any corresponding content for the connected class.

  • Class information stored in the Oracle data dictionary.

If the Oracle database server runs with the HS_AUTOREGISTER server initialization parameter set to FALSE, then information is not stored automatically in the Oracle data dictionary. The equivalent data is uploaded by the Heterogeneous Services agent on a connection-specific basis each time a connection is made, with any instance-specific information taking precedence over class information.


Note:

It is not possible to determine positively what capabilities and what data dictionary translations are in use for a given session due to the possibility that an agent can upload instance information.

You can determine the values of Heterogeneous Services initialization parameters by querying the VALUE column of the V$HS_PARAMETER view. Note that the VALUE column of V$HS_PARAMETER truncates the actual initialization parameter value from a maximum of 255 characters to a maximum of 64 characters. It truncates the parameter name from a maximum of 64 characters to a maximum of 30 characters.

4.10.3 Using the General Views

The views that are common for all services are as follows:

ViewContains
HS_FDS_CLASSNames of the classes that are uploaded into the Oracle data dictionary
HS_FDS_INSTNames of the instances that are uploaded into the Oracle data dictionary
HS_CLASS_INITInformation about the Heterogeneous Services initialization parameters

For example, you can access multiple Sybase gateways from an Oracle database server. After accessing the gateways for the first time, the information uploaded into the Oracle database server could appear as follows:

SQL> SELECT * FROM HS_FDS_CLASS; 

FDS_CLASS_NAME        FDS_CLASS_COMMENTS             FDS_CLASS_ID
--------------------- ------------------------------ ------------
Sybase816             Uses Sybase driver, R1.1                 1
Sybase817             Uses Sybase driver, R1.2                21

Two classes are uploaded: a class that accesses Sybase816 and a class that accesses Sybase817. The data dictionary in the Oracle database server now contains capability information, SQL translations, and data dictionary translations for both Sybase816 and Sybase817.

The Oracle database server data dictionary also contains instance information in the HS_FDS_INST view for each non-Oracle system instance that is accessed.

4.10.4 Using the Transaction Service Views

When a non-Oracle system is involved in a distributed transaction, the transaction capabilities of the non-Oracle system and the agent control whether it can participate in distributed transactions. Transaction capabilities are stored in the HS_CLASS_CAPS tables.

The ability of the non-Oracle system and agent to support two-phase commit protocols is specified by the 2PC type capability, which can specify one of the types shown in the following table.

TypeCapability
Read-Only (RO)The non-Oracle system can be queried only with SQL SELECT statements. Procedure calls are not allowed because procedure calls are assumed to write data.
Single-Site (SS)The non-Oracle system can handle remote transactions but not distributed transactions. That is, it cannot participate in the two-phase commit protocol.
Commit Confirm (CC)The non-Oracle system can participate in distributed transactions. It can participate in the server's two-phase commit protocol but only as the commit point site. That is, it cannot prepare data, but it can remember the outcome of a particular transaction if asked by the global coordinator.
Two-Phase Commit (2PC)The non-Oracle system can participate in distributed transactions. It can participate in the server's two-phase commit protocol, as a regular two-phase commit node, but not as a commit point site. That is, it can prepare data, but it cannot remember the outcome of a particular transaction if asked to by the global coordinator.
Two-Phase Commit Confirm (2PCC)The non-Oracle system can participate in distributed transactions. It can participate in the server's two-phase commit protocol as a regular two-phase commit node or as the commit point site. That is, it can prepare data and it can remember the outcome of a particular transaction if asked by the global coordinator.

The transaction model supported by the driver and non-Oracle system can be queried from the HS_CLASS_CAPS Heterogeneous Services data dictionary view.

The following example shows one of the capabilities is of the 2PC type:


SELECT cap_description, translation
FROM   hs_class_caps
WHERE  cap_description LIKE '2PC%'
AND    fds_class_name LIKE 'SYBASE%';

CAP_DESCRIPTION                          TRANSLATION
---------------------------------------- -----------
2PC type (RO-SS-CC-PREP/2P-2PCC)                  CC



When the non-Oracle system and agent support distributed transactions, the non-Oracle system is treated like any other Oracle server. When a failure occurs during the two-phase commit protocol, the transaction is recovered automatically. If the failure persists, the in-doubt transaction may need to be manually overridden by the database administrator.

4.10.5 Using the SQL Service Views

Data dictionary views that are specific for the SQL service contain information about:

  • SQL capabilities and SQL translations of the non-Oracle data source

  • Data dictionary translations to map Oracle data dictionary views to the data dictionary of the non-Oracle system


    Note:

    This section describes only a portion of the SQL Service-related capabilities. Because you should never need to alter these settings for administrative purposes, these capabilities are not discussed here.

4.10.5.1 Using Views for Capabilities and Translations

The HS_*_CAPS data dictionary tables contain information about the SQL capabilities of the non-Oracle data source and required SQL translations. These views specify whether the non-Oracle data store or the Oracle database server implements certain SQL language features. If a capability is turned off, then Oracle does not send any SQL statements to the non-Oracle data source that require this particular capability, but it still performs postprocessing.

4.10.5.2 Using Views for Data Dictionary Translations

In order to make the non-Oracle system appear similar to an Oracle database server, Heterogeneous Services connections map a limited set of Oracle data dictionary views onto the non-Oracle system's data dictionary. This mapping permits applications to issue queries as if these views belonged to an Oracle data dictionary. Data dictionary translations make this access possible. These translations are stored in Heterogeneous Services views whose names have the _DD suffix.

For example, the following SELECT statement transforms into a Sybase query that retrieves information about emp tables from the Sybase data dictionary table:

SELECT * FROM USER_TABLES@remote_db WHERE UPPER(TABLE_NAME)='EMP';

Data dictionary tables can be mimicked instead of translated. If a data dictionary translation is not possible because the non-Oracle data source does not have the required information in its data dictionary, then Heterogeneous Services causes it to appear as if the data dictionary table is available, but the table contains no information.

To retrieve information about which Oracle data dictionary views or tables are translated or mimicked for the non-Oracle system, connect as user SYS and issue the following query on the HS_CLASS_DD view:

SELECT DD_TABLE_NAME, TRANSLATION_TYPE
FROM   HS_CLASS_DD
WHERE  FDS_CLASS_NAME LIKE 'SYBASE%';

DD_TABLE_NAME                  T
-----------------------------  -
ALL_ARGUMENTS                  M
ALL_CATALOG                    T
ALL_CLUSTERS                   T
ALL_CLUSTER_HASH_EXPRESSIONS   M
ALL_COLL_TYPES                 M
ALL_COL_COMMENTS               T
ALL_COL_PRIVS                  M
ALL_COL_PRIVS_MADE             M
ALL_COL_PRIVS_RECD             M
...

The T translation type specifies that a translation exists. When the translation type is M, the data dictionary table is mimicked.

4.11 Using the Heterogeneous Services Dynamic Performance Views

The Oracle database server stores information about agents, sessions, and parameters. You can use the dynamic performance views to access this information. This section contains the following topics:

4.11.1 Determining Which Agents Are Running on a Host: V$HS_AGENT View

The V$HS_AGENT view identifies the set of Heterogeneous Services agents currently operating on a specified host. Table 4-2 shows the most relevant columns. For a description of all the columns in the view, see Oracle Database Reference.

Table 4-2 Important Columns in the V$HS_AGENT View

ColumnDescription

AGENT_ID

Oracle Net session identifier used for connections to agent (listener.ora SID)

MACHINE

Operating system machine name

PROGRAM

Program name of agent

AGENT_TYPE

Type of agent

FDS_CLASS_ID

The ID of the foreign data store class

FDS_INST_ID

The instance name of the foreign data store


4.11.2 Determining the Open Heterogeneous Services Sessions: V$HS_SESSION View

The V$HS_SESSION view shows the sessions for each agent and specifies the database link that is used. Table 4-3 shows the most relevant columns. For a description of all the columns in the view, see Oracle Database Reference.

Table 4-3 Important Columns in the V$HS_SESSION View

ColumnDescription

HS_SESSION_ID

Unique Heterogeneous Services session identifier

AGENT_ID

Oracle Net session identifier used for connections to agent (listener.ora SID)

DB_LINK

Server database link name used to access the agent NULL means that no database link is used (for example, when using external procedures)

DB_LINK_OWNER

Owner of the database link in DB_LINK


4.11.3 Determining the Heterogeneous Services Parameters: V$HS_PARAMETER View

The V$HS_PARAMETER view lists the Heterogeneous Services parameters and their values that are registered in the Oracle database server. Table 4-4 shows the most relevant columns. For a description of all the columns in the view, see Oracle Database Reference.

Table 4-4 Important Columns in the V$HS_SESSION View

ColumnDescription

HS_SESSION_ID

Unique Heterogeneous Services session identifier

PARAMETER

The name of the Heterogeneous Services parameter

VALUE

The value of the Heterogeneous Services parameter


Information about the database link that was used for establishing the distributed connection, the startup time, and the set of initialization parameters used for the session is also available. All of the runtime information is derived from dynamically updated tables.

PKn- -PKr>AOEBPS/preface.htm* Preface

Preface

This guide describes Oracle's approach for information integration in a heterogeneous environment. Specifically, it describes Oracle Database gateways.

This preface contains these topics:

Audience

This guide is intended for the following users:

To use this guide, you must be familiar with relational database concepts and basic database or applications administration. You must be familiar with the operating system environment under which database administrators are running Oracle software.

Documentation Accessibility

Our goal is to make Oracle products, services, and supporting documentation accessible to all users, including users that are disabled. To that end, our documentation includes features that make information available to users of assistive technology. This documentation is available in HTML format, and contains markup to facilitate access by the disabled community. Accessibility standards will continue to evolve over time, and Oracle is actively engaged with other market-leading technology vendors to address technical obstacles so that our documentation can be accessible to all of our customers. For more information, visit the Oracle Accessibility Program Web site at http://www.oracle.com/accessibility/.

Accessibility of Code Examples in Documentation

Screen readers may not always correctly read the code examples in this document. The conventions for writing code require that closing braces should appear on an otherwise empty line; however, some screen readers may not always read a line of text that consists solely of a bracket or brace.

Accessibility of Links to External Web Sites in Documentation

This documentation may contain links to Web sites of other companies or organizations that Oracle does not own or control. Oracle neither evaluates nor makes any representations regarding the accessibility of these Web sites.

Deaf/Hard of Hearing Access to Oracle Support Services

To reach Oracle Support Services, use a telecommunications relay service (TRS) to call Oracle Support at 1.800.223.1711. An Oracle Support Services engineer will handle technical issues and provide customer support according to the Oracle service request process. Information about TRS is available at http://www.fcc.gov/cgb/consumerfacts/trs.html, and a list of phone numbers is available at http://www.fcc.gov/cgb/dro/trsphonebk.html.

Related Documents

For more information, see the following:

Many of the examples in this guide use the sample schemas, which are installed by default when you select the Basic Installation option with an Oracle Database installation. See Oracle Database Sample Schemas for information about how these schemas were created and how to use them.

Conventions

The following text conventions are used in this document:

ConventionMeaning
boldfaceBoldface type indicates graphical user interface elements associated with an action, or terms defined in text or the glossary.
italicItalic type indicates book titles, emphasis, or placeholder variables for which you supply particular values.
monospaceMonospace type indicates commands within a paragraph, URLs, code in examples, text that appears on the screen, or text that you enter.

PKlY9PKr>AOEBPS/index.htmD Index

Index

A  B  C  D  E  F  G  H  I  M  O  P  Q  R  S  T  U  V 

A

agents
Database Gateways, 2.3.1
Heterogeneous Services
architecture, 2.1
disabling self-registration, 4.4.2
registering, 4.4, 4.4.1, 4.4.1.1, 4.4.1.2
types of agents, 2.3
Oracle Database Gateway for ODBC, 2.3.2
application development
Heterogeneous Services
controlling array fetches between non-Oracle server and agent, 4.2.3
controlling array fetches between Oracle server and agent, 4.2.2
controlling reblocking of array fetches, 4.2.4
DBMS_HS_PASSTHROUGH package, 3.3
passthrough SQL, 3.3
using bulk fetches, 4.2
using OCI for bulk fetches, 4.2.1
array fetches, 4.2.1
agents, 4.2.3

B

bind queries
executing using passthrough SQL, 3.3.3.2
BIND_INOUT_VARIABLE procedure, 3.3.3, 3.3.3.1.4
BIND_OUT_VARIABLE procedure, 3.3.3, 3.3.3.1.3
BIND_VARIABLE procedure, 3.3.3
buffers
multiple rows, 3.3.3.2
bulk fetches
optimizing data transfers using, 4.2

C

callback link, 3.10.2
CLOSE_CURSOR function, 3.3.3
copying data
from Oracle database server to SQL Server, 4.8
from SQL Server to Oracle database server, 4.9
INSERT statement, 4.9

D

data dictionary views
Heterogeneous Services, 4.10
data type checking support
for remote-mapped statements, 4.5.1
DBMS_HS_PASSTHROUGH package, 3.3.1
list of functions and procedures, 3.3.3
distributed queries
optimizing performance, 5.2
dynamic performance views
Heterogeneous Services, 4.11
determining open sessions, 4.11.2
determining which agents are on host, 4.11.1

E

EXECUTE_IMMEDIATE procedure, 3.3.3
restrictions, 3.3.3.1
EXECUTE_NON_QUERY procedure, 3.3.3

F

FDS_CLASS, 4.4.1.2.1
FDS_CLASS_VERSION, 4.4.1.2.1
FDS_INST_NAME, 4.4.1.2.2
features
new, Preface
FETCH_ROW procedure, 3.3.3
executing queries using passthrough SQL, 3.3.3.2
fetches
bulk, 4.2
optimizing round-trips, 3.3.3.2

G

gateways
how they work, 2.7
GET_VALUE procedure, 3.3.3, 3.3.3.1.3, 3.3.3.1.4

H

Heterogeneous Services
agent registration, 4.4
avoiding configuration mismatches, 4.4.1.1
disabling, 4.4.2
enabling, 4.4.1
self-registration, 4.4.1.2
application development
controlling array fetches between non-Oracle server and agent, 4.2.3
controlling array fetches between Oracle server and agent, 4.2.2
controlling reblocking of array fetches, 4.2.4
DBMS_HS_PASSTHROUGH package, 3.3
passthrough SQL, 3.3
using bulk fetches, 4.2
using OCI for bulk fetches, 4.2.1
data dictionary views, 4.10
types, 4.10.1
understanding sources, 4.10.2
using general views, 4.10.3
using SQL service views, 4.10.5
using transaction service views, 4.10.4
dynamic performance views, 4.11
V$HS_AGENT view, 4.11.1
V$HS_SESSION view, 4.11.2
initialization parameters, 2.5.2, 4.1
SQL service, 2.4.2
transaction service, 2.4.1
HS_AUTOREGISTER initialization parameter
using to enable agent self-registration, 4.4.1.3
HS_BASE_CAPS view, 4.10.1
HS_BASE_DD view, 4.10.1
HS_BULK view, 4.10.1
HS_CLASS_CAPS view, 4.10.1
HS_CLASS_DD view, 4.10.1
HS_CLASS_INIT view, 4.10.1
HS_FDS_CLASS view, 4.10.1
HS_FDS_FETCH_ROWS initialization parameter, 4.2.3
HS_FDS_INST view, 4.10.1
HS_INST_CAPS view, 4.10.1
HS_INST_DD view, 4.10.1
HS_INST_INIT view, 4.10.1
HS_RPC_FETCH_REBLOCKING initialization parameter, 4.2.4
HS_RPC_FETCH_SIZE initialization parameter, 4.2.2, 4.2.4

I

information integration
benefits of Oracle solutions, 1.3
challenges, 1.1
how Oracle addresses, 1.2
Messaging Gateway, 1.2
Open System Interfaces, 1.2
Oracle Streams, 1.2
initialization parameters
Heterogeneous Services (HS), 2.5.2, 4.1
initialization parameters (HS)
common to all gateways, 4.1
purpose, 2.5.2

M

Messaging Gateway
defined, 1.2
multiple rows
buffering, 3.3.3.2

O

OCI
optimizing data transfers using, 4.2.1
Open System Interfaces
defined, 1.2
OPEN_CURSOR procedure, 3.3.3
Oracle Database Gateway for ODBC
Heterogeneous Services, 2.3.2
Oracle Database gateways
optimizing SQL statements, 5.1
Oracle database server
SQL construct processing, 4.5
Oracle Net Services listener, 2.2
Oracle precompiler
optimizing data transfers using, 4.2.1
Oracle Streams
defined, 1.2
using for heterogeneous connectivity, 3.2
OUT bind variables, 3.3.3.1.3

P

PARSE procedure, 3.3.3
passthrough SQL
avoiding SQL interpretation, 3.3
executing statements, 3.3.3
non-queries, 3.3.3.1
queries, 3.3.3.2
with bind variables, 3.3.3.1.1
with IN bind variables, 3.3.3.1.2
with IN OUT bind variables, 3.3.3.1.4
with OUT bind variables, 3.3.3.1.3
implications of using, 3.3.2
overview, 3.3
restrictions, 3.3.2

Q

queries
passthrough SQL, 3.3.3.2

R

reblocking, 4.2.4
remote-mapped statements
and data type checking support, 4.5.1
rows
buffering multiple, 3.3.3.2

S

SQL capabilities
data dictionary tables, 4.10.5.1
SQL service
data dictionary views, 2.6.2, 4.10.1
Heterogeneous Services, 2.4.2
views
Heterogeneous Services, 4.10.5
SQL statements
optimizing distributed, 5.1
Synonyms, 4.7

T

transaction service
Heterogeneous Services, 2.4.1
views
Heterogeneous Services, 4.10.4

U

user-defined functions
executing on non-Oracle database, 4.6

V

variables
bind, 3.3.3.1.1
PKoDDPKr>AOEBPS/img/heter009.gifp?GIF87aXp?**?***UU?UUU????**?*******?*******U*U?*U*U*U**?*****?*****?*****?***UU?UUUU*U*?U*U*U*UUUU?UUUUUUUU?UUUUU?UUUUU?UUUUU?UUU?**?***UU?UUU?????**?***UU?UUU?????**?***UU?UUU?ժժ?ժժժ???**?***UU?UUU?????***UUU,Xp H*\ȰÇ#JHŋ3jȱǏ CIɓ(S\ɲ˗0cʜI͛8sɳϟ@ JѣH*]ʴӧPJJիXjʵׯ`ÊKٳhӪ]˶۷pʝK}'0|խ[.Z ԗO`֭[|_>˗|/_>u֭k6_/?|խ[.|_>}o`[|_>ӗ/_>} /_ݺuՅ@O_>~/߿ <0… :|1ĉ+Z1ƍ;z2$~O`>ӗ/?/?$XA .dC%NXE5nG!E$YI)UdK1eΤYM9uOA%ZQI.eSQNM  <0A H*\ȰÇ#JHŋ3jȱǏ % <0a}'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?O_ȉ 2dȐ!C 2dȐ!CB/DB 2dȐ!C 2dȐ!!r?}!C 2dȐ!C 2dȐ#O?~'p HP |߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?O}8`?'p }'p |?8`A&TaC!F8bE1fԸcGAB 8>8`>?} H*\ȰÇ#JHŋ3jȱǏ !GP_AO~ p 0O,h „ 2l!Ĉ'Rh"ƌ7r#HW?8@~'p @}'p <0… :|1ĉ+Z1ƍ;z?}O@ P (߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?OA~8`?'p }'p | ?} H*\ȰÇ#JHŋ3jȱǏ !G_AO~ p 0O,h „ 2l!Ĉ'Rh"ƌ7r#HW?8@~'p @}'p <0… :|1ĉ+Z1ƍ;z?}O@ P (߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?OA~8`?'p }'p | ?} H*\ȰÇ#JHŋ3jȱǏ !G_AO~ p 0O,h „ 2l!Ĉ'Rh"ƌ7r#HW?8@~'p @}'p <0… :|1ĉ+Z1ƍ;z?}O@ P (߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?OA~8`?'p }'p | ?} H*\ȰÇ#JHŋ3jȱǏ !G_AO~ p 0O,h „ 2l!Ĉ'Rh"ƌ7r#HW?8@~'p @}'p <0… :|1ĉ+Z1ƍ;z?}O@ P (߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?OA~8`?'p }'p | ?} H*\ȰÇ#JHŋ3jȱǏ !G_AO~ p 0O,h „ 2l!Ĉ'Rh"ƌ7r#HW?8@~'p @}'p <0… :|1ĉ+Z1ƍ;z?}O@ P (߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?OA~8`?'p }'p | ?} H*\ȰÇ#JHŋ3jȱǏ !G_AO~ p 0O,h „ 2l!Ĉ'Rh"ƌ7r#HW?8@~'p @}'p <0… :|1ĉ+Z1ƍ;z?}O@ P (߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?OA~8`?'p }'p | ?} H*\ȰÇ#JHŋ3jȱǏ !G_AO~ p 0O,h „ 2l!Ĉ'Rh"ƌ7r#HW?8@~'p @}'p <0… :|1ĉ+Z1ƍ;z?}O@ P (߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?OA}8`?'p }'p | ?} H*\ȰÇ#JHŋ3jȱǏ !GP_AO~ p 0ϟ>$XA .dC%NXE5nG# @'p`?O@O|O,h „ 2l!Ĉ'Rh"ƌ7r#Hϟ?8 ?'p @}'p O,h „ 2l!Ĉ'Rh"ƌ7r#HO@ Dh?O@ DPB >QD-^ĘQF=~ џ 2dȐ!C 2dȐ!CO_ȉ 2dȐ!C 2dȐ!CB_? QD-^ĘQF=~_>׏?~Ǐ~gp!C 2dȐ!C 2dȐ+ϟ~o߾}ϟ? 2dȐ!C 2dȐ!C>8p@P+(,h „ 2l!Ĉ'Rh"ƌ7r#ȋ'p ~,h A,h „ 2l!Ĉ'Rh"ƌ7r#ȅ HP`} HП'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?z> 4xaB O@ DPB >QD-^ĘQF=~OH $H A $H A:$ȃ@ $H A $H | A $H A $H `> A $H A $Hy0H A $H A C@<$H A $H A ҡ?} O@ Dp_?$/,h „ 2l!Ĉ'Rh"ƌ7rG8p |'p "L/_>~ O@ DPB >QD-^ĘQF=~P? 4xaBP _?$XA .dC%NXE5nGO@$XA(p_} 8} <0… :|1ĉ+Z1ƍ;z_}O@ DР?ӗO?$XA .dC%NXE5nNjO@ DP!~'p AO@ DPB >QD-^ĘQF=~O~,h „ ? o,h „ 2l!Ĉ'Rh"ƌ7r} H*4? ? 4xaB 6tbD)VxcF9vdH9rȑ#G9rȑ#GZodA9rȑ#G9rȑ#G^̧o~(p_O@ DPB >QD-^ĘQF=~I_|Bӗo_~ۗ/_>!C 2dȐ!C 2dȐ˗|(?'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?/_|uܗO~'p`>$XA .dC%NXE5nG8? 4h_|8?O@ DPB >QD-^ĘQF=~I|O@ ԧ`?'P`}'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?08`Aǯ_~O_|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?`>O@ /_>}˗O? H*\ȰÇ#JHŋ3jȱǏ /'p A$X,h „ 2l!Ĉ'Rh"ƌ7r#ȍۗ/? 2dȐ!C 2dȐ!C/_>!C 2dȐ!C 2dȐ!C /!C 2dȐ!C 2dȐ!_Ȑ!C 2dȐ!C 2dȐ/dȐ!C 2dȐ!C _|w|/dȐ!C 2dȐ!C _|40|/dȐ!C 2dȐ!C 1|_~˗߿}7P_|˗?}`>~/_?$X|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?v߾|/~_|G0}_߿|_|@ $H A $H _~ 7}/_|/߿|O`>A/? A $H A $Ȇ ߿|߿|o>}(0|˧_ ϟ|8|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?r@~o` /'P__>~"| $H A $H A2o|o| ̗`>O|˷O`>A/? A $H A $H_|@ $H A $H A̗C~ $H A $H A9H$H A $H A $E~ $H A $H A@_>$/_>}ۗ/>_|G | /?$XA .dC%NXE5nG ̗0_>O@}7p߿|ӧ߾|˗_Ȑ!C 2dȐ!C >}/@}/|ܗ@O?}د߿|/_|˷O`| /dȐ!C 2dȐ!C y_ۧO`>_>̗/_> '0__?~۷?~˗_Ȑ!C 2dȐ!C b|뗏| O |/߿˗/'p|_> 7p? 4xaB 6tbD)VxcF9vb}O`>'0A} O|/_ ̗`> _|@ $H A $H ǯ_| '0?˧O|'P_70_>}$H A $H A |70@}'0_AO`?}/_W0}_|@ $H A $H A/_> A $H A $@ $/?$XA .dC%NXE5nG!E/#G9rȑ#G9rȑoȑ#G9rȑ#G9r?~9rȑ#G9rȑ#GF70D5/#G9rȑ#G9rd|I1_C~9rȑ#G9rȑ#A˗o|/߾/|ۗ/?/_>˷O | א_|F9rȑ#G9rȏo| 䗏߿}o?~/@~߿㗏߿}o߾'p  <0… :|1ĉ+Z1;z1_+/| O`|/|/_k/_> A $H A $H O` /|˧/_|3O`|70| $H A $H A 2|'0_}ۧ_ ̧@}3O|ӷ/ א_|@ $H A $H ˗O? ˗Oϟ|O`>o_|ۗ/>O@? 4xaB 6tbD)VxcF9vdHoȑ#G9rȑ#G9r?~9rȑ#G9rȑ#G_|F9rȑ#G9rȑ#G/#G9rȑ#G9rȑoȑ#G9rȑ#G9r?~9rȑ#G9rȑ#G_|F9rȑ#G9rȑ#G/#G9rȑ#G9rȐۗ/?9rȑ#G9rȑ#Gv08`A&TaC!F8bE1fԸcGA`>O@ DPB >QD-^ĘQF=~#| O@ DPB >QD-^ĘQF=~> <0… :|1ĉ+Z1ƍ;z2$HO@ DPB >QD-^ĘQF=~2$|'RH"E)RH"E)2b|)RH"E)RH"E/_~"E)RH"E)RH"''RH"E)RH"E)b?"E)RH"E)RH"E)RH"E)RH"E)RH"E)RH"E_?$XA%L0!~8`A&TB'p "Lp!ÂO@ DPB >QD-^Ę~%˧?5jDϟFQF5jԨQFi/FiԨѠ?5j\OF5jԨQF)#П <`| &L(߿'p "Lp!CO@ DPB,h „ 2l!Ĉ'Rh"ƌ > QFQƁӨQF5jԨQFӨQcAiԨѠ4jXП@5jԨQF5jHџ@!˧4jh@5j,O?5jԨQF5jO?@5j4o?5'ПF5jԨQF5R'ПFilo?57ПF OF5jԨQF)O~ (p_>'p QD-^Ę?4П   QFӨ ?O?5jԨQF5jO?QԧQ4jh@5o?~ QF5jԨQF >4 7ПF OƃM?4jԨQF5jԨ?4GQFӨQAix'ПF5jԨQF5R',h`A}ԇ!BC!B"D"D!BCp?~  <0… :|1ĉ+Z1Ai<> QFӨ ?O?5jԨQF5jO?QԧQ4jh@5o?~ QF5jԨQF >4 7ПF OƃM?4jԨQF5jԨ?4GQFӨQAix'ПF5jԨQF5R'Пƃ((@5j4o?7ӨQF5jԨQFO@ ,!B"DH@"D!B7B"Dp ??8`A&TaC!F8bE1f4 7ПF OƃM?4jԨQF5jԨ?4GQFӨQAix'ПF5jԨQF5R'Пƃ((@5j4o?7ӨQF5jԨQFxPE}OF QA~&ϟ@5jԨQF5jHџ@ H!DHPB !B"D!BC!B!',h „ 2l!Ĉ'Rh"ƌ >4 7ПF _?$X ,h B~"?'p "Lp!ÆB(q"Ŋ/bxП@꣨O@iԨѠO@ O@ DBO?$XA .dC%NXEOA}io?57?}iTDOF5jԨQF)OA}io?57?}iTD QF5jԨQF O@ ,? ,? 4x߿'p "Lp!C>$XA'p #? 4xaB 6tbD)Vxcƃ4*GQF4jh_A}iTA~  ? 4xaB 6tbD)VHџ?'P @'p "D/a„ %L(P_„ K0a„ &L8_A}  ԗ0a„̗P?~'p "Lp!ÆB(q"ŊO>$X>} <Bԇ!A}"D!B"D!B C>"$A~ Ǐ?$XA .dC%NXA'P>}ϟ?ϟ?ӧ/_|G A $o? $H $H> $HP?'p "Lp!C𠾆 wP|'p}O@ DPB >QD-/_|w~˗O? B}],o/>7?}]l|ϟ@/^xŋ/^O_||8П@꣨bA]x񡿁飨bC~xŋ/^x"|wb}wџ@꣨bA]x񡿁飨bC~'p ϟ@ H*\ȰÇ#JHD~gA~O/?飨ϢAYhQ飨DϢE-ZhѢEϢŅGџ@%'_BGQEhѢDGQB _>}ϟ@-ZhѢE-Z,/_>~->ԗoDП@ OE} ϢE OE}Y,A~Ϡ?~ g"C O@ O@ DPB >Q"AM8 |$ @??} H`A} 4H@ 4hРA 4hР3hР@} ߿O@g_>g3hРA Ǐ>} HA} <0… :|1|$Jp_} '>ITo?%Jdo$ 'Q"?_>'ПDۧ/_|ǯ?ϟ?~ӗ/_|(QD%J/?%.ܗDI|O@}OD>I}Ϡ?~ 'Q"~˗o?/_|(QD%Jt/D?$>'Q> 'QD OD$J}?O?$XA˗/߾~ &L8߾|K0a„ &L0a„ &L80 &L0!|%4O ԗ0@} &o &L0a O_„%L0!?gK0!~/a„ ۗ/> &L0a„ &L0a„ K0a„ ? /a„%L(P_„ /a„ &L0@ӗ0@} &L_A ?O?$X!B"/_>}8`A&TaC!>̗/bĈϟCE/@}/bĈ!E(ϟ@˧_Ĉ ˗_Ĉ#F1|E|П@!8P_ą1bD/@}# 3?El/_>~#FD/#F1bĆ1bąϟ?Q_ā".7_Ĉ#B7?}Q ?/>'_Ć1~E1bĈ#b| <0‚뗯? o…&ԷpA-\p…  -\p ?_>'…p… ˷o… .\p… |-\pB/_?'… -LoB[p… 7?} [p@~o߿|O o… *ܗ… .\p… .ϟ@p… ˷ϟ?p?.\oaB} 7… .\A8` 4hРA~ /_} ϟ@ 4H_> 4hРA ,h „ 2l!Ą/_>~#:/_} @$HП@ ,X@} ,` 7,h „ 24oװB~gkP>} 6lP`}6lذaÆ 6l(0?˧  /_|8_~8 A,X`,X ,8@ H*\РkxP_Æ ;ϟBaC5lذaCװaÆ 6lذa!O_|װ~˗o?@$HП@ ,X@} ,` 7,h „ 24oװB~˗'_ÆkذaÆ_Æ 6lذaÆ ǰ߾|ӷ_??}˧o_?$(0_? H? ,X` ,XP_ o?$XA .dh@5~8`A O@ W` W` ,X@'p "Lp!CA} *?~˗?~ װ@}kذaÅ_Æ 6lذaÆ 0?'p A?8`A O@ W` W` ,X@'p "Lp!CA} *`|@aC˧aÆ ˗}5lذaÆ 6l_> 6dП O $O ,Xp W`? 4xaB 7?} kP!?S?5l(PװaÆϟ}5lذaÆ 6l_> 6dП O $O ,Xp W`? 4xaB 7?} kP!?/'_Æ/_~ 6l_|o? 6lذaÆ 6_Æ 'p  ` | ` 7,h „ 24oװB~ _|?6~װaÄ˧?_Æ 6lذaÆ װaC H|'p AW` WP`?~ W`#? 4xaB GП5l|7_Æ3o_|kذ~˷?'? 4xaB 6t"|"FП O $` ,O_A $H A O@ DPB𠾆 W0}3A  /!?}_Æۗ/_>}8p}8`A&TaC!"/bĈ H|'p A ,X`/~+X`O@ DPB𠾆 W0_Ϡ?~5l(P?'P>~O@ Ǐ|ӷ@o@$XA .dC1"@,/_? H ,X?}˗/>~+X`O@ DPB𠾆 Wp_|Ϡ?~5l(Pۧ`>8?~'p}8`A O@ DPB >0#'p  +X` WP`>WP>$XРA  <0… +A} O@ ,h>~?~80?8`A O@ DPB >0#'p  +X` WP`>WP>$XРA  <0… +A} O@  ? $A 4h@$XП}8`A&TaC!"/bĈ H|'p A ,X`/>}? 4h?'p "Lp!C kxP_C8`'p #ϠA gРA 48? o@$XA .dC1"@,/_? H ,X?}˗O'p  'P?$XA .dh_A} k(@,Xp?$X}4h A} 4hРA'p  <0… :|a>#FO@'? W` @~ ? 4h?'p "Lp!C kxP_C H}8P |A $H A}8`A&4П ӷO ,h „ 2l!DE? @$H_ ,X🾂_ ,X`A8`A&TA5} G_Ækذ!C$XП}8`A&TaC!"/bĈ H|'p A ,X`菟| W`  <0… +A} *`>g?6_Æ 'p  <0… :|a>#FO@'? W`  ~+(P_ ,(,h „ 24诠5l/AkP>~ 6dП ӷO ,h „ 2l!DE? @$H_ ,X🾂˷_ ,X`A8`A&TA5~ G_Ækذ!C$XП}8`A&TaC!"/bĈ H|'p A ,X`_,X`,_ ,X` +XP ,XP_A,Xp_A/_>} Ǐ ,8P ,X`'p  <0… :|a>#FO@'? W` | `  A~,X` ,X`>} WP_ +8p_| ̗o_A,X?~,X`,X` ,? o@$XA .dC1"@,/_? H ,X?}W?} ,X@˗/ ,X` ̗/>+`/_| ,/_| W`>'p?~O@ <(? o@$XA .dC1"@,/_? H ,X?}'p G A $~ ? 4xaB(pG> $ ?O@8߿O@ GПA ϠA 4hp @,O> H*\ȰÇ1bD$X_~8 A ,X` ,XP_ ,(@8P@~,h „ 'p`} 诟>}8p`> 4xp`'p~?}P <? 4xaB H?}'p "Lp!ÆBD_Ĉ8`A O@ D!|!Ǐ?_?~ Ǐ?~O|,h „ .?O,XP?} H/>Ǐ? H'p "Lh? o@$XA .dC1"@,/_>$Xp?$XA˗/>~ӧ?}O>}ӧ?}O>}`> 4xaB ? 7p '| O@8P`'p|#(?$H A'p "Lh? o@$XA .dC1"@,/_? H ,X?}/߿|+X`#`>'p "L |@ 7p 7?O@8߿O @#H A  <0A$XП}8`A&TaC!"/bĈ H|'p A ,X`߿|` 诠?}ǯ` ,X`(G> $@~G Ǐ?~/_| Ǐ? $H>~ HO@'? 4xaB 6t"|"FП O $` ,O_AO_A ,X`A /_>~ ,X` $/_>~ +`/_ ǯ@~ />G_ _ ,X`8`A O@ DPB >0#'p  +X` Wp|+(P_ ,(_A+X` ,X | 篠 Wྂ+(p_A,X?~,X`,X` ,? o@$XA .dC1"@,/_? H ,X?}_>}+X`O@ DPB𠾆kH˗OAkP>~ 6dП ӷO ,h „ 2l!DE? @$H_ ,X🾂/_}+X`+X` W` ,8_A} ,`+X@~ o~ Ǐ ,8P ,X`'p  <0… :|a>#FO@'? W` `>~/_A ,X`A ,X`,X` WP_ +X@~ ,(_#` ǯ` ,X` H?}'p "Lp!ÆBD_Ĉ8`A O@,X`+O>}` ` ,XP_ ,X@,X `+(~+? ,X@} ,X` П ӷO ,h „ 2l!DE? ?$X_ ,X🾂|+X`+X` W` ,8_A} ,`+X@~ ,H? ,X@} ,X` П ӷO ,h „ 2l!DE? ,ϟA 4|󗏟 4hР@ 4h A} 4hР 3hР@} ϠAgРA3hРA П ӷO ,h „ 2l!DE? ,@$X8P_}8P>$XA < &$H AO@ D @,O> H*\ȰÇ1bD$X_> H? 4hР> gРA3hРA 3hРA WPA3h ? ?O@ < H*\ȰÇ1bD$X_> H? 4hР> gРA3hРA 3hРA WPA3h ? ϠA#ϠA gРA 48? o@$XA .dC1"@,/?$X? 4hPAgP> 4(ПA 4HPA 4h🿂 4(PA3h ?˗O_?#ϠA gРA 48? o@$XA .dC1"@,/?$X? 4hP˧ 4hР@ 4h A} 4hР 3hР@} Ϡ08'p wП ӷO ,h „ 2l!DE? ,ϟA 4|?} 4hP? 4h> 4h?菠? ,ϟA+o?3A 4HP? 4hР H?}'p "Lp!ÆBD_Ĉ8`A'p 4hРA _ gРA3hРA 3hРA WPA3Ϡ4X 3A 4HP? 4hР H?}'p "Lp!ÆBL_Ĉ8`A'p 4hРA ۗO>~ gРA3hРA 3hРA WPA ? 8p@ 8p@ o|7?$XA}3hРA4hРA4hРA+Ϡ@} 3h ? |ӷϠ?~4h A} 4hРA'p O@ DPB >_#'p 'p 4hРA 4(PA ϠA $ϠA 4_A}O@7p7p7p |O@ <'p ?$XA%L0AӇ`>8P@,(p_? $o$H A'p "Lh? ,h „ 2l!ć1BO_|8`A 4hРA}70 4hР@ 4h A} 4hР 3hР@} Ϡ$Ϡ@3hРA4hРA O@ <0… :|?}1A/_>~ HAQ|'Q@ӗ/~(QA~˧>IHPDԇ_|3/"?;Bp_>'p O@ DPB > }ǯ? ӗ/_}$*'Q>>IHPDԇ03/"?;o?~IT/?'p 'p "Lp!ÆBhП~˗/}џ?~˗/_>}IlOD}˗/$:'Q"A}%WP|ϠE ~ #O|$JtП ˷? 4xaB 6tbDo>P 8P>~'p !Bo~C!B"DPB"诠>OA}!O@o? HӇ!BO@ <0… :|1C ׏}ӧO} <Р H'p|@} H? 4x!A} &Lx@%ܗ/>'p 3h> H A gРAϠA 4X? /,h „ 2l!Ĉ'p A HPB/_>})TP? *ԧPBԇ`>?} H@~ ,ϟAGПA /_>~ 4hРA HП|8`A&TaC!F8bE,:GQE,Jg'p>}_D~˗O?gq!|YП˗,h „ 2l!Ĉ'RxПEPE,Jg#_>" ܧϠ?~Ydo_|YП? 4xaB 6tbD)VLϢC}[ϢB%X_A}/߿|E/"?g?,>ܗ/_},B>}gѢE-ZhѢE;0 OA $H? $H A'p "<诠>˗?~%D_BO |#/a„ ۗ/_>}K0!A˗O? H*\ȰÇ#JHbC꣨ϢB%X_A} /_| GПʼnӗ/_|D/_|gѢE-ZhѢE'p ˧'p ?$XA%L0Aӗ_}П Ϡ'p@~#8>'p "Dϟ~O 0? 4xaB 6tbD)VϢC}'p`? A $HA $H A8`AWP~ϟA} !?8P 7?$XA 'p`?~ O>},h „ 2l!Ĉ'RhѠ Էϟ@w1]诠>/B}_A̧?,h „8 A$XA .dC%NXbC+`.&w1g0_>}C/"?Kȏwŋ/^xŋ/*w ;bB#H_A}˗/_~E/"?SA/^xŋ/^xB+/_?;bB#H_A} ˗/A}_A~ ?,h „ 2l!Ĉ'Rh"ƌiT |O$H A$H A $? 4xA%菟A} !?8P 7?$XA .dC%NXEП QD-^Ę? QԧѠ?i诠>"QF5jԨQFiT>itOcDQMǏ?5jԨQF5jOB}i4OC}#+Eo?~iԨQF5jԨQ#E꣨OA_A}E/"?#OF5jԨQF)ӨPE} Pƈ ꣨/"?A5jԨQF5jHџF H| H!D!B}"Dp H| H@~ ,> 4߿'p "Lp!ÆB(q"Ŋ/bx@$XA .dh߿8`Aԗ0a„ O@ DXp_ &,? H*\ȰÇ#JHŋ3QF4:ԧ1?(џF5jԨQF5RQF4:ԧ1?(џF5jԨQF5RQƅitOcD4FOD5jԨQF5jHFѡ>?iԨQF5jԨQ#E4jԨƇ4J1"?#QF5jԨQFQƂQƉ萟?QF5jԨQFiԨ`?#H_?FiFiFi@8`A&TaA 6,aÆ5l? 6aÆ 6lذaÆ 6lذaÆ 6lذa~ 6lذaA 6,aÆ5l? 6aÆ 6lذaÆ 6lذaÆ 6lذa~ 6lذaA 6,aÆ5l? 6aÆ 6lذaÆ 6lذaÆ 6lذa~ 6lذaA 6,aÆ5l? 6aÆ 6lذaÆ 6lذaÆ 6lذa~ 6lذaA 6,aÆ5l? H O@ DPB >QD-^Ęa?$XA .dX,h B&L0~ H 0a„8`A&TaC!F8bE1flП <0… 'p "D/a„  O@ DXp_ &, <0… :|1ĉ+Z1ƍ;zG}Ǐ?~Ǐ?6F~>~Ǐ?~ǏQ#??~Ǐ?~Ǐ }?~Ǐ?~dž>~Ǐ?~Ǐ?~cC}?jǏ?~Ǐ?~5Ǐ?~Ǐ?~PǏǏ?~Ǐ?~lG}Ǐ?~Ǐ?6F~>~Ǐ?~G}QCO@ DPB O@ DPB >QD-^ĘQF=~l$H $H A $H ; #? A $H A $Ȏ@H A $H A ? 1$H A $H A E~@ $H A $H AH A $H A $H $H A $H '0_>!|70> O@ o@~ ? O@_|'P'p ? 4xaB 6tbD)VxcF9v/||'0_ ̧_>}C/_| '_>}/||+/߿|<ϣG=zѣG=z80_>˗o ~/߿|˷/_?;/_| 'p_~/_>̗o ~ԗ߿|<ϣG=zѣG=z8`>?/|_|$H_|0@@0 o_|/@~ O@ HO@ DPB >QD-^ĘQF%'0_>˗A o`>}'p ̗|WP`|+8?}˗O|W` ,h „ 2l!Ĉ'Rh"ƌ7r(1_>o`|O߿|O?}W0_> ԗϟ@˗O`|/_|70_>ѣG=zѣG=̗O`|_>}O߿|˧O|+/|˧O|/A~O_|G0_>ѣG=zѣG=̗O`|˗o|/_˷| 'P>'? (_|˗> 7P>$XA'p "Lp!ÆB(q"Ŋ/b̨q#ǎ? )r ?#G9rȑ#G9r? 08`A O@ H&? 4xaB 6tbD)VxcF9vdH9rȑ#G9rȑ#G9#G9rȑ#G9rȑ9rȑ#G9rȑ#G9#G9rȑ#G9rȑ9rȑ#G9rȑ#G9#G9rȑ#G9rȑ9rȑ#G9rȑ#G9#G9rȑ#G9rȑ9rȑ#G9rȑ#G9rȑ#G9rȑ#G9rȑ#G9rȑ#G9rȑ#G9rFiF|o|8P |70?'P(?O8P |>ۗ?o@~ H*\ȰÇ#JHŋ3jȱLJ ̗O_~w0_?}㗏|g0_/߿|ˇ0_> ̗O|/|>~Ǐ?~Ǐ/_|;/_|/_̗`|/_?˗O`|/߿} o|_> Ǐ?~Ǐ?~`>  ̗/_>}/߿} |`>'߿8`>8P`|/|O>~ۗ/>~8`A&TaC!F8bE1fԸcG/߿~`|/~`|3/| '0_> o}۷߿~  <0… :|1ĉ+Z1ƍ;zt/|/| '0 ̗`|3/@} _|C/@}O|˗ϟ|o`|?~Ǐ?~G ̗_>w0_㗯?~O|g0_/߿|ˇ0_>O} ̗O`||>~Ǐ?~Ǐ/?~ۇ0_o |C/A O>'?'p_>˧@}7_|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ? )r$ɒ&OLr%˖.O@ H`A ? 4x? <0… :|1ĉ+Z1ƍ;z2ȑ$K<2ʕ,[| 3̙4kڼ3Ν<{ 4СD=4ҥL:} 5ԩTZ5֭\z 6رd˚=vl@;;PK{*IppPKr>AOEBPS/img/heter002.gif,!GIF87aX?**?***UU?UUU????**?*******?*******U*U?*U*U*U**?*****?*****?*****?***UU?UUUU*U*?U*U*U*UUUU?UUUUUUUU?UUUUU?UUUUU?UUUUU?UUU?**?***UU?UUU?????**?***UU?UUU?????**?***UU?UUU?ժժ?ժժժ???**?***UU?UUU?????***UUU,X H*\ȰÇ#JHŋ3jȱǏ CIɓ(S\ɲ˗0cʜI͛8sɳφ H*\Ȱ}8`A&TaC!F8bE1fԸcG'p "Lp!Æ'p "Lp!ÆB(q"Ŋ/b̨q#ǎ7Dž}Ǐ?~Ǐ7Dž}Ǐ?~Ǐ7Dž}Ǐ?~Ǐ7Dž}Ǐ?~Ǐ7Dž}Ǐ?~Ǐ7Dž}Ǐ?~Ǐ7W߾|_ ˗/b>#|?~Ǐ?~ǍO@}拘 |A1F~>~Ǐ?~G}F߿ϟ>߾|_|˗߿ӗo߿˧߿_/_>~˗?}|/|'p A~8`A&TaC!F8bE1fԸcG#/|ۗϟ|_> o_˷O`}O`?}O`o|˧_?~Ǐ?~~w0߿|/߿| W_O`| ̗_>'П~O` '0| Ǐ?~Ǐ?n엏|_ӗ/_>} '0_A _?@ ̷_>/| 7p'p "Lp!ÆB(q"Ŋ/b̨q#ǎ7G_>}_ _#/_? _>}O߿|ӗ߿|/|ۗ߿}O!|?~Ǐ?~Ǎ/_}?}o`>/@˧/_>˗߿|/_}ۧO| ܗ/> ̧_?~Ǐ?~~>:g0G}Ǐ?~Ǐ7a>8`A&4/,h „ 2l!Ĉ'Rh"ƌ7rqc|?~\/Ǐ?~Ǐ?~qc|?~\/Ǐ?~Ǐ?~qc|?~\/Ǐ?~Ǐ?~qc| H*\Ȱa}8`A&TaC!F8bE1fԸcG'p "Lp!Æ'p "Lp!ÆB(q"Ŋ/b̨q#ǎ9'p "Lx_> *T8? 4xaB 6tbD)VxcF9vdDB 2dȐ!C 2dȐ!C$/_Ȑ!C 2dȐ!C 2dȐ 2d!C 2dȐ!C |!C 2dȐ!C 2dȐ!C/dȐ!C 2dȐ!C 2dH 2dȐ!C 2dȐ!C I_!C 2dȐ!C 2dȐ! 2dȐ!C 2dȐ!C 2$AB 2dȐ!C 2dȐ!C$/_Ȑ!C 2dȐ!C 2dȐ 2dȐ!C 2B )B O@ DPB >QD-^ĘQF=~R@F9rȑ#G9rȑ#Goȑ#G9rȑ#G9r@F9rȑ#G9rȑ#Goȑ#G9rȑ#G9r@F9rȑ#G9rȑ#Goȑ#G9rȑ#G9r@F9rȑ#G9rȑ#Goȑ#G9rȑ#G9r@F9rȑ#G9rȑ#Goȑ#G9rȑ#G9r@F9rȑ#G9rȑ#G_>$XA .dC%NXE5nG!EoH8`A&TaC'p "Lp!ÆB(q"Ŋ/b̨q#Gu(Q_>$XA .dذa>} H*\ȰÇ#JHŋ3j|;Jԗcǎرcǎ;vرcǎױD}:vQ;vرcǎ;v|;Jԗcǎرcǎ;vرcǎױD}:vQ;vرcǎ;v|;Jԗcǎرcǎ;vرcǎױD} ˗ױcǎ;vرcǎ;"cG/_?:v|O_ǎ;vرcǎ;v_%g0|˧O_>߿|/_> H*\XP>$XA .dC%NXE5n_'p @ۗO>~ϟ|_8`A&T>} H*\ȰÇ#JHŋ3j|#O@ @߿|'0_? 4xaB  <0… :|1ĉ+Z1ƍb|8W`>?߿O@ DPƒ'p "Lp!ÆB(q"Ŋ/b̨q#Gu|/@~o_>}/|uP;vرcǎ;v||/_~O_||:vlO_ǎ;vرcǎ;v_(P_>ױcG}:vرcǎ;vرcGul/c/_>}:vO_ǎ;vرcǎ;v_ q|;vO_ǎ;vرcǎ;v_ ב|;v@'p "Lp!ÆB(q"Ŋ/b̨q#GuT/߾رcD}:vرcǎ;vرcGuL/߾رcD}:vرcǎ;vرcGuD/O@ DPB  <0… :|1ĉ+Z1ƍa|O@ DPB  <0… :|1ĉ+Z1ƍ|:vh_;vرcǎ;vرcG:ܗ_ǎױcǎ;vرcǎ;v/_ǂر#B:vرcǎ;vرcǎH_>~;vL/_ǎ;vرcǎ;vرc|˷cǎ رcǎ;vرcǎ'p "L/B ˧Pa} H*\h_>$XA .dC%NXE5nȰ|,h „ 2lP ,h „ ? 4xaB 6tbD)VxcF92_ǎ!ױC:vرcǎ;vرcGر#D~:vt/_ǎ;vرcǎ;vȰ_>;v/_ǎرcǎ;vرcǎcǎѡ|;vرcǎ;vر#~u"|;:cǎ;vرcǎ;vd/;Bb?$XA ˷p…  <0… :|1ĉ+Z1c~iԨ1#|'p "Lp!Æ&O@ DPB >QD-^Ęb|4jԘ_>iԨQE}4jԨQF5jԨQ#~iԨ1#|ӨQFiԨQF5jԨQFӨQcF~ ˧QFӨQF5jԨQFQƌAԗOF-˧QF5jԨQFOF僨/F5ZԗOF5jԨQF5"ϟF3Q_>5j/F5jԨQF5jD/?5f|/}'1}? W`/_+X`8`A&TaC!F8bE1Z_ƌ3|/|/b>/?(O|_ed/cƌ3f̘1cƌ/cƌQ_/?~_|O|| /?˗|/|˗o|ۗ///߾|| Է/O_>}O} /1cƌ3f̘1cF <0… 2ϡ@} _|o|G0_>ǯ?}/?o_>/_}ϟ|/߾|/|/}5ԗa|_>?} __>:tСC:tСC:t`|:tСCs(P_/_| 70|/~/@˧O`|ӗ/'0>~O| ߿| H| Ǐ_| H`~/߿߿__?~ H*\ȰÇ#JHŋ #F僨/_|˗/_/_|'_>} ̷_/||ӧ~ۗO`>}ӗO`>˧/˗? 4_߿~_?}/߿?  <0… :|1ĉ+Z_>1bx_>̗|o>#/>o`ӗ߿|@}|˗?~˗O>~'0| /C}.O`_>O` ̧@~0bĈ#F1bH_>1bx_>̗O|˧ϟ|/_>}/>}˗o|˗_A~70_>˧ϟ|˗߿| ?|/A O`>˗/_˗O>~ ϟ|ӗ/?$XA .dC%NXńÈ#ƃAԗ#FÈq|1bĈ#F1bĈ~ܗ/>)ܗ/_>~12|1b̗#FaĈ#F1bĈ#F G0_>/|#ƅAԗ#F0b,/F1bĈ#F1bĨ_>'_}_|˗|o`|/_>~˷/|˗߿|aT/D}0bĈA}0bĈ#F1bĈ#F߿߿|_~ۗϟ|ۗ/>~_>~/?_>~O@ 4/B!D!B"D!B  <0… :|1ĉ+Z1c~ ̗`| o_|_>}؏|'0_/߿|˗OB~  <0… :|h0_>$XA .dC%NXE+o|˧_˗/_|˗/> ̗/|o}˧/_|iT/D} H*\ȰÇ 8`A&TaC!F8bE1f//_/|/?}'_>ӧ@}/_>_> ӨQF5jԨQF5jԨc|ۗ/~ ԗo>'0?G_|/_>~̗O?}OB~4jԨQF5jԨQF5j/?5fOF5jԨQF5jԨQFӨQcF~4jԨQF5jԨQF5j/?5fOF5H#4H#4H#4# <0… 2? 4xaB 6tbD)VxcF9v_>?~T/Ǐ?~Ǐ?~qc|>~_?~Ǐ?~~}Q!|?~Ǐ?~ǍB~>~Ǐ?~ǏG}Ǐ?~Ǐ7Ǐ Ǐ?~Ǐ?nǏǏ?~Ǐ?~/?*Ǐ?~Ǐ?~_>?~T/Ǐ?~Ǐ?~q# <0… 2? 4xaB 6tbD)VxcF9v_>?~T/Ǐ?~Ǐ?~qc|>~_?~Ǐ?~~}Q!|?~Ǐ?~ǍB~>~Ǐ?~ǏG}Ǐ?~Ǐ7Ǐ Ǐ?~Ǐ?nǏǏ?~Ǐ?~/?*Ǐ?~Ǐ?~_>?~T/Ǐ?~Ǐ?~q# <0… 2? 4xaB 6tbD)VxcF9v_>?~T/Ǐ?~Ǐ?~qc?$XA .dС@$XA .dC%NXE5n#G$XA .d/> O@ DPB >QD-^ĘQF=~ra|"E)RH"E)RH")˧OH"E)RH"E)R$E)RH"E)RH"E/>"E)RH"E)RH'RH"E)RH"E)|DO@ DPB O@ DPB >QD-^ĘQF'ϣA} H*\Ȱ|8`A&TaC!F8bE1fԸcljy4/@,h „ 2lP>$XA .dC%NXE5nؑb>} ѣGyѣG=zѣG ˧#A}=zѣG=zѣ~y/GѣG=zѣG=z=zѣG=zѣB}uԗ |QcC}?߿O@ DPƒ'p "Lp!ÆB(q"Ŋ/b̨q#ǎ7G_~߿}߿|B}>~Ǐ?~Ǐ#/@˗O_>'0|cB}>~Ǐ?~ǏcO|?fԧǏ?~Ǐ?~Q_>nj}Ǐ?~Ǐ7Dž}Ǐ?~Ǐ7Dž}Ǐ?~Ǐ7Dž}Ǐ?~Ǐ7/,h „ 2lP>$XA .dC%NXE5nF} H*\Ȱ|8`A&TaC!F8bE1fԸcG'p "LP_ .,? 4xaB 6tbD)VxcF9v$EB 2dȐ!C 2dȐ!C$/_Ȑ!C 2dȐ!C 2dȐ 2dȐ!C 2dȐ!C |!C 2dȐ!C 2dȐ!C/dȐ!C 2dȐ!C 2dH 2dȐ!C 2dȐ!C I_!C 2dȐ!C 2dȐ! 2dȐ!C 2dȐ!C 2$AB 2dȐ!C 2dȐ!C$/_Ȑ!C 2dȐ!C 2dȐ 2dȐ!C 2B )B O@ DPB >QD-^ĘQF=~@},h „ [p… O@ DPB >QD-^ĘQF=0 <0… :|? 4xaB 6tbD)VxcF9vXP_?~/Ǐ?~Ǐ?~|?~(P_?~Ǐ?~cA}>~Q|?~Ǐ?~ǂ}@}>~Ǐ?~ǏG}Ǐ?~Ǐ Ǐ廘Ǐ?~Ǐ?~d/_|7q_|I̷p_|5G1߿|'0;/G>~Ǐ?~cG} '0_> 0?$XP`>_>~ 3hР| ̧|?} 4X@}O_|_|ۗ@~/_> H*\ȰÇ#JHŋ3jq|/_70|ܗ@/?~/_>~ ܗ/? o_>/>}/_>~˧_>~'_ oA}.߿|o߿|O`>~| ױcǎ;vرcǎ;ԗ`|/ |#/߿|_߿|/߿~_>'p_>㗯|O@˷ AП /߿O>߿߿|_>~O@ DPB >QD-^ĘQF+/?~70|̗`| o_ '0߿|G?}|_> ̗/|-/˗ ? ,߿|/߿/߿~/߿?  <0… :|1ĉ+Z1ƍW0_˗o`>˗/?} O߿|_|˧/_|70_'߾|O_|O`>5ԗb>o`_>o| cǎ;vرcǎ;v/_|˗o_>~o`>/_/?}_ o |˧_|O`|'P_| 0_]'0|/_˗O>~?}/_>~ H*\ȰÇ#JHŋ3jq|/߿}'0|O_?˷O?'0?W_| ̗O?}/?/|1̗|;vرcǎ;vرcǎa>~-ױcǎ;vرcǎ;vhP_|;vرcǎ;vرcǎѡرcǎ;vرcǎ;v4/_ǎ;*ԗcǎ;vرcǎ;vѠ|;vP_;vرcǎuQGuԑA <0… :|h0_>$XA .dC%NXE5ncA} H*\ȰÇ 8`A&TaC!F8bE1fԸcGA9dI'QTeK/aƔ9fM7qԹgO?:hQG&UiSOF:jUWfպkW_;lYgѦUm[E;;PK{xHZ,,PKr>AOEBPS/img/heter006.gif@#GIF87aXw?**?***UU?UUU????**?*******?*******U*U?*U*U*U**?*****?*****?*****?***UU?UUUU*U*?U*U*U*UUUU?UUUUUUUU?UUUUU?UUUUU?UUUUU?UUU?**?***UU?UUU?????**?***UU?UUU?????**?***UU?UUU?ժժ?ժժժ???**?***UU?UUU?????***UUU,Xw H*\ȰÇ#JHŋ3jȱǏ CIɓ(S\ɲ˗0cʜI͛8sɳϟ@ JѣH*]ʴӧPJJիXjʵׯ`ÊKٳhӪ]˶۷pʝKJUg׮]g׏b>v=O_}ӧ/߿}_|Ϯ]vo_>ӗo_>?~k׮]߿|'0_Ϯ]v'P'P@}/߿| H*\ȰÇ#JHŋ3jȱǏ C2@~o_>}/|)RH"E)RH"Evo|˧/?}o`)RH"E)RH"Eϟ@}D)RH"E)RH"EF/>"E)RH"E)RH"E)RH"E)RH"EdOH"E)RH"E)RdE}"E)RH"E)RH"+)RH"E)RH"EYQH"E)RH"E)RȊO@ DPB >QD-^ĘQF=~R$A}#G9rȑ#G9rȑ# 9rȑ#G9rȑ#GIPȑ#G9rȑ#G9rHF9rȑ#G9rȑ#G7rȑ#G9rȑ#G9#G9rȑ#G9rȑ9rȑ#G9rȑ#G$oȑ#G9rȑ#G9r$A}#G9rȑ#G9rȑ# 9rȑ#G9rȑ#GIPȑ#G9rȑ#G9rHF9rȑ#GiFiH,h „ 2l!Ĉ'Rh"ƌ7r| H*\P_ 6lؐ`>$XA .dC%NXE5n>=zPG=zѣG=zQG=zdϣG=zѣG=zϣG=2ѣG=zѣG=BѣGѣG=zѣG!ѣG yѣG=zѣGyѣG=zѣG H*\P> 2dȰ ,hP>8`A&TP> 2dȰ` O@ DP…8`A&TaC!F,/@},h „ &̗!C 2$? 4(P@~8`A&T0a| 2dȐ|O,h0@},h „ &? 4xaB 6tbĂ(QDI(Q@$'>%J/?%JOA}'QD(QD%Jt/?%JOD%Ob~(QD(Qā'q`>%J(0?%J(QD(QDI(Q@$"ODOD'a>%J(0?%J(QD(QDI(Q@$"ODOD'a>%J(0?%J(QD(Q"H>$XA .L/CcȐ!C !C 2OCcȐ!C ǐ!C 2dȐ!C !C 2OC 2d8_> ǐ!C  C 2d8P> ǐ!C  Ǐ!C 2dȐ!C  C 2d(P> 2dp|  䧏!C 2/? 2dp>}  !C 2C 2dȐ!C 2/? 2dP>} 2dȐ@2OC 2d(_> 2dȐ@O@ %J(P>%J/DI(Q@I(Q@}$"OD'QD%J_>%J(P>%J`> 4xP,h „ "C 2d8P|,h?$XA .DC 2dȐ!C 2/? 2dP>} 2dȐ@8`AO@ DPBcȐ!C П ,,h „ "Ǐ!C 2dȐ!C  C 2d(P> 2dp|  䧏!C 2/? 2dp>}  !C 2C 2dȐ!C 2/? 2dP>} 2dȐ@2OC 2d(_> 2dȐ@}2C 2d(0? 2dȐ!C 2d(_> 2dȐ@}2dȐ!Á1d(> 2dP|2dȐ!Á1d(0? 2dP`>~ 2dȐ!C 2dP|2dȐ!CO,h „ &!C/Ä2dx_> 2dȐ@}2A  ? 4xaB 6tbĂ(QDI(Q@$" |IOă(QāID|'`> 'QD%J_>%J(P>%J/Ḑ/>ӗ߾| /_~'QbAI(Q@}$"`|/_>~˧_>~˷O|˗DI(QD%:ϟD% ԧOD'!?}/@}˷/?|Ix_>%J8 }8`A#/|/_o|/,,h „ 2l!Ĉ'QD#/|(Q@$"䧯 |/| ̗_(|$J(q>}G`>_߿|O ,h`|8`A&TaC!F,/?%JO|w0D'!?}(p߿|o_>$XA0a„ &L8P G0_>ӗ/_>} '0߿|_>}ӗ0aB%L0a„ &L0a„ &,/ &L0aBO`|O_|˗߿|/߾ӗ߾| /_~˷O`˗o@&DOA _>O~ /_„ _„ &L0@}&D|ӧ@}O`O|_„ 0a„J(J(J(* 'p "Lp!B}'p}/߿_>~o߾/߾|/_߾}/߿˷?8`A#/@˗O_>'0|w /?}O`>˗O?ӗ/4,h „ 2l!Ĉ'QD#/|'0_|/_> '0| ̗__@$"䧏?I(q|$J(q>}'QD(QD%Jt/?%JO|/|'0|'0_/|o`|o`>˷O|ǐ_|I(q|$J(q>}'QD(QD%Jt/?%JO|>~?}/߿O߿ۗO߿o}| H~ H*\ȰÇ#_}1D #/|ӗ//_>~ ܗ/>˧/?}o`|O_| O"B~ ˗O_?I8_>˗|%J,OD̗/_>~!'Q|$J(QD`|1D (?I|/D̗O |%JL/?󗏟D'a>/(qa>~%J(QD7p_>o߿|/__? 4x!A}&L|K0A&DO} ߾|/_~_~/_>~ &4/? ̧_~/|˗߿|%L0A}&D|_|˗| />'_|˗_„K0a„ &L0a„ &LX_>#/߿|___„ ԧ/a„ &Lp| "䧏`|/|o_>__~ HG0_>ǯ߿|/}/~"Dp>}"|O?|o?}ϟ|/?? 4xaB 6tbĂ/|؏߾|_ ̗Oāܗ/_>~I_>#/|'0_|˧O`|/@`|o`>/>(1>}G0_>o_>/|׏߾|_>}x0?%J(QD/?o`}˗`˗OD/_(QB$"䧏|˗O_|0߿|˧/߿˗? 4x|'0o>~˗/|"D>}"|/>~o| ̗_} /_}˗OB <0… :|1bA O}70߿~_>~'P_?70_ۗ/?ۗO`>~˗}(_>#/>O~@} O_>_>/_/_>_>'a>/_'0||/?~˧@}$OD%J(ѡ|ۗ/~ ԗo˷_OD /_}ۗϟ|ׯ__>~ۗϟ|8`Aˇ!B/_}ӗ/O_|?}C!#/_|o`|˗߿|"D>}"|'P_}O_}ӗ/ϟ|/_>~",h „ 2l!Ĉ'QD#؏|'0_/߿|_>}_>(QD(QāIDϟD% OD%J(ѡ|$J(Q>}/_>}/}_|˗/>哈>%J/?%JODI(Q|$J(QDOD7_>ӧ@}/_>ӗ߿|ĈIDOD% ϟD%ԧ? 4X0 ϟ|/_>~%'!?}˗o$J|/?%JODI(Q|$J(QDOD'QD哈>/|%>ϟD%ԧO"|$J(Q`>~%J(QD'QD(QāIDO} | ܗ/|OĄ(QāIDϟD% OD%J(ѡ|$J(@ <0… cP ?}+/|/? "C 2d8P> ǐ!C  Ǐ!C 2dȐ!C  C 2d(P> 2dp|  䧏`|/_'0_> "C 2d8P> ǐ!C  Ǐ!C 2dȐ!C  C 2d(P> 2dp|  䧏|ӗ/| /|cȐ!B1dȐ!CcP`> 2dȐ|2dC 1C 1C/?$XA .DOC 2d8_> G_>}ۗ߿}o_ ׏!Cǐ!C ԧ!C1dȐ!CcȐ!C 2dȐ!Cǐ!C  ԧ!C 2/C+O_|ۗ/>˷O?ǐ!ÄcȐ!C |2dȐ!C1dȐ!C 2dȐ!CcȐ!C ǐ!C !C1dȐ!Cǐ!C ԧ!C1dȐ!CcȐ!Cb!b!_> H*\P> 2dp|  䧏!C 2/? 2dp>}  !C 2C 2dȐ!C 2/? 2dP>} 2dȐ@2OC 2d(_> 2dȐ@}2C 2d(0? 2dȐ!C 2d(_> 2dȐ@}2dȐ!Á1d(> 2dP|2dȐ!Á1d(0? 2dP`>~ 2dȐ!C 2dP|2dȐ!C1dȐ!CcP ?} 2dȐ@O@ DP„1d(0? 2dP`>~ 2dȐ!C 2dP|2dȐ!C1dȐ!CcP ?} 2dȐ@1dȐ!CcP`> 2dȐ|2dȐ!C 2dȐ@1dȐ!CcȐ!C ǐ@~2dȐ!CcȐ!C ǐ|2dȐ!C1dȐ!C 2dȐ!CcȐ!C ǐ!C !C1dȐ!Cǐ!C ԧ!C1dȐ!CcȐ!C 2d!bH  <0…cȐ!C ǐ@~2dȐ!CcȐ!C |2dȐ!C1dȐ!C 2dȐ!CcȐ!C ǐ!C !C1dȐ!Cǐ!C ԧ!C1dȐ!CcȐ!C 2dȐ!CП <0…cȐ!C  ,O@,h „ "䗯C 2d8P>$X`|8`A&Ta>~ H*\ȰÇ#0 <0… :|1@$X`A~ H*\ȰÇ# ,0 <0… 'p "Lp!ÆBh? 4xaB cȐ!C 'p  'p "Lp~ 2dȐA$X`A$XA .\ <0… :|1ĉ+Z1ƍ;z2ȑ$K<2ʕ,[| 3̙4kڼ3Ν<{ 4СD=4ҥL:} 5ԩT$Z5֭\z 6رd˚=6ڵlۺ} 7\;;PKSS%E#@#PKr>AOEBPS/img/heter008.gifNtGIF87aX?**?***UU?UUU????**?*******?*******U*U?*U*U*U**?*****?*****?*****?***UU?UUUU*U*?U*U*U*UUUU?UUUUUUUU?UUUUU?UUUUU?UUUUU?UUU?**?***UU?UUU?????**?***UU?UUU?????**?***UU?UUU?ժժ?ժժժ???**?***UU?UUU?????***UUU,X H*\ȰÇ#J`? 4xaB 'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?/@},h „  ? 4xaB 6tbD)VxcF9v>~ A$H A $H A >~ A$H A $H A >~ Aԗ/? A $H A $HIP_|@ $H A $H $A} $H A $H AtH$H A $H A >~ Aԗ/? A $H A $HIP_|@ $H A $H $A} $H A $@ $h?$XA ./_>~ H*\ȰÇ#JHŋ3jȱǏ | $H A $H A:|P_|@ $H A $H W1_?P_|@ $H A $H Gq_?ӧ/>'P߾|.˗H A $H A }(3_~O ?wQ_|@ $H A $H G1| ̗@~ wQ_|@ $H A $H GQ_?_ _'p ˗,h „ 2l!Ĉ'Rh"7r}(O?}>}/|$H A $H A >~˗O_?ϟ| '0E} $H A $H At_| ˗H A $H A }:iP_|@ $H A $H 7q_|@6ԗ/? A $H A $HIO>~ ˗H A $H A }$7| >}o_|Ǐ,8P_|8`A&TaC!F8bE1fԸcG='1| /۷}/_>~ A $H A $H`>o| $H A $H A:Ob>O`>/|Qԗ/? A $H A $HIO }O`o?棨/_>~ A $H A $H/_}ӧO`?}| $H A $@ $@r}8`A&TP|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?z$H$H A $H Ap? ˗H A $H A }@$/_>~ A $H A $H | $H A $H A:$H$H A $H Ap? ˗H A $H A }@$/_>~ A $H A $H | $H A $H A:$H$H AH H C <0…? 4xaB 6tbD)VxcF9v>~ Aԗ/? A $H A $H8`A&T ?$XA .dC%NXE5nG'p "Lp@~ H*\ȰÇ#JHŋ3jȱǏ O@ DP8`A&TaC!F8bE1fԸcGA O@ /BO@ DPB >QD-^ĘQF=~2_!C 2dȐ!C 2dȐ! 2dȐ!C 2dȐ!C 2$|B 2dȐ!C 2dȐ!C$/_Ȑ!C 2dȐ!C 2dȐ 2dȐ!C 2dȐ!C `|!C 2dȐ!C 2dȐ!C̗/dȐ!C 2dȐ!C 2dH 2dȐ!C 2dȐ!C I0_!C 2dȐ!C 2dȐ! 2dȐ!C 2dȐ!C 2$|B 2dȐ!C )B )B"|8`A&TaC!F8bE1fԸcGA90_#G9rȑ#G9rȑ9rȑ#G9rȑ#G90_#G9rȑ#G9rȑ9rȑ#G9rȑ#G90_#G9rȑ#G9rȑ9rȑ#G9rȑ#G90_#G9rȑ#G9rȑ9rȑ#G9rȑ#G90_#G9rȑ#G9rȑ9rȑ#G9rȑ#G90_#G9rȑ#G9rȑʗ? 4xaB 6tbD)VxcF9vdH9rȑ#G9rȑ#G90_#G9rȑ#G9rȑ9rȑ#G9rȑ#G 08`A&TaC!F8bE1fԸcGA`>'p "Lp!ÆB(q"Ŋ/b̨q#ǎ? `>'p "Lp!ÆB(q"Ŋ/b̨q#ǎ? r_|)RH"E)RH"E1_|)RH"E)RH"E/_>}"E)RH"E)RH"'OH"E)RH"E)RD~D)RH"E)RH"E)RH"E)RH"E)RH"E)RH"E)RH"E)RH"E)RD$XA .$ <0… :|1ĉ+Z1ƍ;z| H*\(0?$XA .dC%NXE5nGI? A $H A $HI? A $H A $HI_|@ $H A $H $A~ $H A $H AtȏH˧$H A $H A !?~ A/> A $H A $HI_|@ $H A $H $A~ $H A $H AtȏH˧$H A $H@ $@r ~8`A&TP |'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?z$H$H A $H A? ˗OH A $H A C~@$/_>} A $H A $H | $H A $H A:$H$H A $H A˧ȅ$H A $H Ar!| $H A $H A:ob>˗@}˗ϟ@~/_>} AH H H C 7>_>/@~ ,/_>} H*\ȰÇ#JHŋ3jȱǏ/_|'0?} O $H A $H A Ǐ_>ۗ?  /_>} H*\ȰÇ#JHŋ3jȱǏ񛘯`>'?$H A $H A ˗O>~/_~˗E~ $H A $H AtȏH˧$H A $H A !?~ A/> A $H A $HI_|@ $H A $H $A~ $H A $H AtȏH˧$H A $H A !?8`A&TP |'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?z$H$H A $H A? ˗OH A $H A C~@$/_>} A $H A $H | $H A $H A:$H$H A $H A? ˗OH A $H A C~@$/_>} A $H A $H | $H A $H A:$H$H AH H C <0…˧? 4xaB 6tbD)VxcF9v#?~ A/> A $H A $HI_|@ $H A $H O@ DPB8`A&TaC!F8bE1fԸcGA0 <0…'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?`> 4xaB O@ DPB >QD-^ĘQF=~)? 4xP`|"Dh? 4xaB 6tbD)VxcF9v$|B 2dȐ!C 2dȐ!C$/_Ȑ!C 2dȐ!C 2dȐ 2dȐ!C 2dȐ!C `|!C 2dȐ!C 2dȐ!C̗/dȐ!C 2dȐ!C 2dH 2dȐ!C 2dȐ!C I0_!C 2dȐ!C 2dȐ! 2dȐ!C 2dȐ!C 2$|B 2dȐ!C 2dȐ!C$/_Ȑ!C 2dȐ!C 2dȐ 2dȐ!C 2B )B ~8P`| H*\ȰÇ#JHŋ3jȱǏ Cn̗/_?)RH"E)RH"ET0@O ,h „ 2l!Ĉ'Rh"ƌ7r#H'p "LX`>O ,h „ 2l!Ĉ'Rh"ƌ7r#H H*,@$XA .dC%NXE5nG <0!A? H*\ȰÇ#JHŋ3jȱǏ /$|W0_!C 2dȐ!C 2dH 1_>~ 2dȐ!C 2dȐ!CD/%̗/dȐ!C 2dȐ!C |Bj̗/dȐ!C 2dȐ!C |Bj̗/dȐ!C 2dȐ!C |Bj̗/dȐ!C 2dȐ!C |Bj̗/dȐ!C 2dȐ!C |B^Ǐ_| 2dȐ!C 2dȐ!C,/8P ,h „ 2l!Ĉ'Rh"ƌ7r#Ȃ y|O@ DPB >QD-^ĘQF=~YP_>!1'p ,h „ 2l!Ĉ'Rh"ƌ7r#H _| 2dȐ!C 2dȐ!C4/˗/dȐ!C 2dȐ!C |Bf/!C 2dȐ!C 2dȃ 1_!C 2dȐ!C 2dH _Ȑ!C 2dȐ!C 2dB}iO@ DPB H*\ȰÇ#JHŋ3jȱǏq_>$XA .,h „ 2l!Ĉ'Rh"ƌ7r#A}e$H $H A $H )/>~ AH A $H A r|2$A} $H A $H AJԗ_}@$/_>~ A $H A $H˸H$H A $H A)Q_>/_|c| $H A $H %/>~o|$H A $H A)Q_>`O߿߾|O@ ԗ/?$XA .dC%NXE5nG˸E _/߾| /_>~ H*\ȰÇ#JHŋ3jȱǏq? ̷O`>˗o`>$H A $H A/Y̗O`| 70_|aԗ/? A $H A D}eb|O`o_>$H A $H A/YO@/߿'p>$X@}O@ DPB >QD-^ĘQF=~/IP_|@ $H A $Hq? ˗H A $H A R|2$A} $H A $H AJԗ_}70>3| $H A $H %/>~ '0_? 櫨/_>~ A $H A $H˸_|'_|O>/|/_>~$H A $H AI" $AۧO ǯ|_}߾|w|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ? ԗ_}/?'0|ۗ_> />9ԗ/? A $H A D}ea}/| ̷_'0߿|˧ϡ| $H A $H %/>~70߿~#O`_}O~$H A $H A)Q_>s/'0|ۧ>}?}{/_>~ AH H H $@O@ QD-^ĘQF=~/IP_|@ $H A $Hqb1ԗ/? A $H A D}eO!?~e'0C} $H A $H AJԗ_}_|O?}O | /_~O`>-ԗ/? A $H A D}eOao|/|o߾O '? 4xaB 6tbD)VxcF9vQ|20߿|O`| /_O`?~ 70B} $H A $H AJԗ_}/| ̗_70߿| ̷_>[/_>~ A $H A $H˸_B>}O߿|ۗ߿}O` '_$H A $H A/)߾|O_|_>߿||߿}8?}O@ DPB >QD-^ĘQF=~/)a>[/_>~ A $H A $H˸B>$H A $H A/-R$H A $H A/IP_|@ $H A $Hq? ˗H A $H A R|2$A} $H A $H AJԗ_}@$/_>~ A $H A $H $`> 4xaB O@ DPB >QD-^ĘQF=~/?8`A&Tp ?$XA .dC%NXE5nG`> 4xaB O@ DPB >QD-^ĘQF=~/? $H A $H AĨ/? $H A $H AĨ/? $H A $H AĨ/? $H A $H AĨ/? $H A $H AĨ/? $H A $H AĨ/? $H A $H AĨ/? $H A $H AĨ/? $H A $H AĨ/? <0… :|1ĉ+Z1ƍ;z!|,h „ 'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?D`> 4xaB8`A&TaC!F8bE1fԸcGA90_#G9rȑ#G9rȑ9rȑ#G9rȑ#G90_#G9rȑ#G9rH;/ȑ#G9rȑ#G9r$G~W0_#G9rȑ#G9 ? 4xaB 6<`>O ,h „ 2l!Ĉ'Rh"ƌ7r1#|,h „ 2l0߿8`A&TaC!F8bE1fԸcGO@ DPB O@} <0… :|1ĉ+Z1ƍ;z̘/Ǐ˗/>Ǐ?~Ǐ?f̗Ǐ`|?~Ǐ?~nj}?}Ǐ?~Ǐ3dž}Ǐ?~Ǐ3dž}Ǐ?~Ǐ3dž}Ǐ?~Ǐ3dž}Ǐ?~Ǐ3dž}Ǐ?~Ǐ3G (? 4xaB 6tbD)VxcF9vh1_?*08`A&TaC!F8bE1fԸcGBO@ DPB >QD-^ĘQF=^̗Ǐ ˗/߾?~Ǐ?~|>~0_|>~Ǐ?~Ǐ#C~Ǐ?~Ǐ?b̗Ǐ Ǐ?~Ǐ?f̗Ǐ Ǐ?~Ǐ?f̗Ǐ?~Ǐ?~Ǐ Ǐ?~Ǐ?~c|>~Ǐ?~Ǐ?~0_O@ DPB8`A&TaC!F8bE1fԸcljyp>$XA .,h „ 2l!Ĉ'Rh"ƌ7r81_>#B}~="ԧ?=zѣG=zѣ|#B}ѣG=zѣG= ̗ϣGyP_|~="ԗ/?=zѣG=zѣ|#B}ѣGyGyGy@ <0…cȐ!C? 4xaB 6tbD)VxcF9v/G |yѣG=zѣG#}~=zѣG=zѣGyp?˗G=zѣG=zQ`|=2ϣGѣG=zѣG=z/G |yѣG=zѣG#}'P?$X0_ ,XP|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ>~ 1w0ǃѣG=zѣG=z/G K |ӗO?~_~/_>?~˗G=zѣG=zQ`|=2/a '0?~/_o?/߾˗G=zѣG=zQ`|=2/a|@~7߿|!/|/߿| ϣG=zѣG=z@ <0…K |_> '070|o? 4xaB 6tbD)VxcF9v/G K>~}'0|/@}o|yѣG=zѣG#}+O_|O_|aO ?}c/_>~=zѣG=zѣG!#B}ѣG=zѣG=zq?'p?$X`A}O@ DPB >QD-^ĘQF=~H$H A $H A >~ Aԗ/? A $H A $HIP_|@ $H A F  <(0B"4B"D!A}O@ DPB >QD-^ĘQFX0GyP_|O  ߾_> |yѣG=zѣG˗O_+@~op?˗G=zѣG=zx1| W`>Ǐ_(0| H0a„ &,/_>~ H*\ȰÇ#JHŋ3jȱ#|/|_>o| >~="ԗ/?=zѣG=zb>O`|O_|c}~=zѣG=zѣG!#B}ѣG=zѣG=zq?˗G=zѣG=zѣGyP_|8`A&TP|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ/_>?~~?~ϣG0 <0…'p "Lp!ÆB(q"Ŋ/b̨q#ǎ70?/G 'p "Lp@~ H*\ȰÇ#JHŋ3jȱ#| '0~qa?$XA!Da~ H*\ȰÇ#JHŋ3jȱ#|/@}ϣG ѣG=zѣG=z?}O?=zѣG=zѣG=r̗ϣG=zѣG=zѣGѣG=zѣG=z#|=zѣG=zѣG=r̗ϣG=zѣG=zQ!?~=z/G=zѣG=zѣ|=zѣGyGyB <0… :/,h „ 2l!Ĉ'Rh"ƌ7r1c|?~l/Ǐ?~Ǐ?~1c|?~l/Ǐ?~Ǐ?~1c|?~l/Ǐ?~Ǐ?~1c|?~l/Ǐ?~Ǐ?~1c|?~l/Ǐ?~Ǐ?~1c|?~l/Ǐ?~Ǐ?~1c|?~/_}Ǐ?~Ǐ3ǁׯ`|?~Ǐ?~nj}lП <0} ߿8`A&TaC!F8bE1fԸcGP|,h „ O ,h „ 2l!Ĉ'Rh"ƌ7r1c|P <0aA? H*\ȰÇ#JHŋ3jȱnj}l/˗/?}Ǐ?~Ǐ3|>Jԗ/?}Ǐ?~Ǐ3|>Ja|?~Ǐ?~nj}l/Ǐ?~Ǐ?f̗cC}}/Ǐ?~Ǐ?~1c|c}˧O߾?~Ǐ?~|>6ԗnj80,h „ 2l!Ĉ'Rh"ƌ7rb|cF ? 4xaB 6tbD)VxcF9vh1_ Q> O@ DPB >QD-^ĘQF=^̗cC}}/_|}Ǐ?~Ǐ/|>nԗ/_?~Ǐ?~#|>6ԗǍǏ?~Ǐ?~Ę/dž}/Ǐ?~Ǐ?~1c|?~Ǐ?~Ǐ?~L/Ǐ?~Ǐ?~ǏǏ?~Ǐ?~DŽ}P|,h „  <0… :|1ĉ+Z1ƍ;N̗ϣGyP_?=zѣG=z#|.'P?$X!B"D~ H*\ȰÇ#JHŋ3jȱ|.h0}~?}|>~="ԗ/?=zѣG=zѣ|.˗/`>~_>~="ԗ/?=zѣG=zѣ|.+o`>'P~/o@'p "Lp@}O@ DPB >QD-^ĘQF#w1_A}'0A}?'0|!ϣGѣG=zѣG=z/|˗|˗?~ϟ| '0}~=zѣG=zѣGyp?˗G=zѣG=zQ`|=2ϣGѣG=zѣG=z/G ۸/_>}<ԗ/?=zѣG=zѣ|<>~_| (0A $8P_|8`A&TaC!F8bE1fԸcLjy,ϣ}2GO_>}ϣG=zѣG=z(0_'p_|O`>/?q'|ϣG=zѣG=z(0_>߾}_>/_?/}2/_| '0F}ѣG=zѣG= ̗bO`O`>>~#`> 4/_>~ H*\ȰÇ#JHŋ3jȱc|,+o`>O`>O`>e엏@'6˗G=zѣG=zQ`|}_ '0| q?˧>'0?ѣG=zѣG=z/Eϟ| o_>}O`>惸GϣG=zѣG=z(0_>#B}ѣG=zѣG= ̗ϣG o`}3hРA? 4xaB 6tbD)VxcF9v/G o~y/_>~=zѣG=zѣGyp? 7_|O`>gQ_|~o@_>'E}ѣG=zѣG= ̗ϣ~4W1߿} '0߿|O ?ѣG=zѣG=z/G˸_E} 짏|'0?  ԗ/?$XA .dC%NXE5n1b|/>~70 /߿~'ѣG=zѣG=z/G˸|˗O>~ۗOϢ|yѣG=zѣGѡ|2#B}ѣG=zѣG= ̗ϣC}eϣGѣG=zѣG=z/G˸GϣG=zѣG=z(0_>q?˗,h „ 2l!Ĉ'Rh"ƌ7r1_>q?˗G=zѣG=zQ`|/>~="ԗ/?=zѣG=zѣ|<:ԗ_}~=zѣG=zѣGyt/yP_||yѣG=zѣGѡ|2#B}ѣG=zѣG= ̗ϣC}eϣGѣG=zѣGyG/,h BK>~ &L0a‚ <0… :|1ĉ+Z1ƍ;F̗ϣC}eܗ> 4xaB ˗,h „ 2l!Ĉ'Rh"ƌ7r1_>_?} H*\8,h „ 2l!Ĉ'Rh"ƌ7r1_>Ǒ|,h „  <0… :|1ĉ+Z1ƍ;F̗ϣC}q <(0_>",? 4xaB 6tbD)VxcF9v/G1_>=zѣG=zѣGyt/?ѣG=zѣG=zT/G1_>=zѣG=zѣGyt/?ѣG=zѣG=zT/G1_>=zѣG=zѣGyt/?ѣG=zѣG=zT/G1_>=zѣG=zѣGyt/?ѣG=zѣG=zT0_>$XA0a„ ̗? 4xaB 6tbD)VxcF9v1_ O@ DPa|8`A&TaC!F8bE1fԸcGP|,h „ 'p "Lp!ÆB(q"Ŋ/b̨q#ǎ3!@,h „  <0… :|1ĉ+Z1ƍ;z̘/ǏǏ?~Ǐ?~̘/ǏǏ?~Ǐ?~̘/ǏǏ?~Ǐ?~̘/ǏǏ?~Ǐ?~̘/ǏǏ?~Ǐ?~̘/ǏǏ?~Ǐ?~̘/ǏǏ?~Ǐ?~̘/@,h „ 2l_| H*\ȰÇ#JHŋ3jȱnj H*\Ȱ H*\ȰÇ#JHŋ3jȱnj H*\ȰÁ'p "Lp!ÆB(q"Ŋ/b̨q#ǎ? )r`|#G9rȑ#G9rȑ#7rȑ#G9rȑ#G9r`|#G9rȑ#G9rȑ#7rȑ#G9rȑ#G9r`|#G9rȑ#G9rȑ#ӗ/>}F9rȑ#G9rȑ#AO| H*\ȰÇ#JHŋ3jȱǏ C~08`A&TaC!F8bE1fԸcGA`>8`A&TaC!F8bE1fԸcGA /_|)RH"E)RH"E/_|"E)RH"E)RH"%˗H"E)RH"E)Rȉ)RH"E)RH"E)RH"E)RH"E)RH"E)RH"E)RH"E)RH"E)Rȉ H*\H? 4xaB 6tbD)VxcF9v}8`A&TP`~ H*\ȰÇ#JHŋ3jȱǏ  ~ A $H A $H >~@ $H A $H $A} $H A $H AtH$H A $H A >~ Aԗ/? A $H A $HIP_|@ $H A $H $A} $H A $H AtH$H A $H A >~ Aԗ/? A $H H C <0…? 4xaB 6tbD)VxcF9v>~o`>$H A $H A >~| ˗H A $H A }(7|ϟ| /?$H A $H Ap?o?o?~/_>~ A $H A $H`ӷ|/_>~ A $H A $H񣘏>_}O@ HA}O@ DPB >QD-^ĘQF=~E~'0?}o` 篢| $H A $H A:ǯ"| ϟ|˗/_Ϣ| $H A $H A:$H$H A $H Ap? ˗H A $H A }@$/_>~ A $H A $H/_>~ ˗H A $H A }$'p? $H A $@ $@ $? @~ 'P}'p_|ϠA <0… :|1ĉ+Z1ƍ;zq?O`>~߾}D} $H A $H At| '0?} 70|$H A $H A >~'0| /| $H A $H A:O"}_|70?}'0E} $H A $H AtD~/>}/_~˗|$H A H H C <0…? 4xaB 6tbD)VxcF9v>~ Aԗ/? A $H A $HIP_|@ $H A $H $A} $H A $H AtH$H A $H A >~ Aԗ/? A $H A $HIP_|@ $H A $H $A} $H A $H AtH$H A $H A >~ Aԗ/? A $@ $@ $h?$XA ./_>~ H*\ȰÇ#JHŋ3jȱǏ | $H A $H A:0 <0…'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?`> 4xaB O@ DPB >QD-^ĘQF=~|,h „  <0… :|1ĉ+Z1ƍ;zR @,oh „ O@ DPB >QD-^ĘQF=~RH%MDRJ-]SL5męSN=}TPEETRM>UTU^0 ;;PKd?NNPKr>AOEBPS/img/heter007.gifJGIF87aX?**?***UU?UUU????**?*******?*******U*U?*U*U*U**?*****?*****?*****?***UU?UUUU*U*?U*U*U*UUUU?UUUUUUUU?UUUUU?UUUUU?UUUUU?UUU?**?***UU?UUU?????**?***UU?UUU?????**?***UU?UUU?ժժ?ժժժ???**?***UU?UUU?????***UUU,X H*\ȰÇ#JHŋ3jȱǏ CIɓ(S\ɲ˗0cʜI͛8sɳϟ@ JѣH*]ʴӧPJJիXjʵׯ`ÊKٳh'p "LpaA$XA .dC%NXE5nG 90_Ȑ!C 2dȐ!C 2|!C2dȐ!C 2dȐ!C /_Ȑ/dȐ!C 2dȐ!C 1_Ȑ/dȐ!C 2dȐ!C 1_Ȑ/dȐ!C 2dȐ!C 1_Ȑ/dȐ!C 2dȐ!C 1_Ȑ/dȐ!C 2dȐ!C 1_Ȑ/dȐ!C 2dȐ!C 1_Ȑ/dȐ!C 2dȐ!C 1_Ȑ/dȐB )B )B )>(,h „ ̗/?$XA .dC%NXE5nG.˗O? $H A $H A a> H$H A $H A0_}O|˗ϟ@}/_> A $H A $HUg0߿|/@~b| $H A $H A:W1| ̗@~ w1_|@ $H A $H 櫨A0/,hP`|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?zW_>~/'滘/_> A $H A $HY/_>}ӗo?'0|$H A $H A a>@̗/? A $H A $H<i0_|@ $H A $H 棸/_>~ ˗H A $H A |H$H A $H A0D}O`>/_>˗߿O@ ˗,h „ 2l!Ĉ'Rh"ƌ7r|'0|߾}'0?$H A $H A0| '0@} 70|$H A $H A aO`>ۗ_櫘/_> A $H A $HMO }O`>ӷ|U̗/? A $H A $H(˗o}O|/_~U̗/? A $H A $H? 4xaB ˗,h „ 2l!Ĉ'Rh"ƌ7r| A̗/? A $H A $H@,/_> A $H A $HY0_|@ $H A $H  `| $H A $H A:d| $H A $H At$Ȃ$H A $H A0H$H A $H A a> ˗H A $H A | A̗/? A $H A $H? 4xaB ˗,h „ 2l!Ĉ'Rh"ƌ7r| A̗/? A $H A $H8`A&Tp`|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?zׯ|,h „  <0… :|1ĉ+Z1ƍ;z>$XA .? 4xaB 6tbD)VxcF9v~ Hˇ!B8`A&TaC!F8bE1fԸcGAO_Ȑ!C 2dȐ!C 2dȐ2dȐ!C 2dȐ!C 2@ 2dȐ!C 2dȐ!C 9_>}!C 2dȐ!C 2dȐ!CO_Ȑ!C 2dȐ!C 2dȐ2dȐ!C 2dȐ!C 2@ 2dȐ!C 2dȐ!C 9_>}!C 2dȐ!C 2dȐ!CO_Ȑ!C 2dȐ!C 2dȐ2dȐ!C 2dȐ!C 2@O@ DPB >QD-^ĘQF=~R@9rȑ#G9rȑ#G/#G9rȑ#G9rȑ7rȑ#G9rȑ#G9R|F9rȑ#G9rȑ#G Oȑ#G9rȑ#G9rH9rȑ#G9rȑ#G)_>}#G9rȑ#G9rȑ#˧oȑ#G9rȑ#G9r@9rȑ#G9rȑ#G/#G9rȑ#G9rȑ7rȑ#GiFiFi$O,h „ 2l!Ĉ'Rh"ƌ7r#Ȑ"˧oȑ#G9rȑ#G9r@9rȑ#G9rȑ#G/#G9rȑ#G9rȑ7rȑ#G9rȑ#G9R>}oȑ#G9rȑ#G9$| <0… :|1ĉ+Z1ƍ;z2G~  <0… :|1ĉ+Z1ƍ;z2dH  <0… :|1ĉ+Z1ƍ;z2dH~'RH"E)RH"E)Rb|)RH"E)RH"E/_>"E)RH"E)RHO@ DPB >QD-^ĘQF=~RH%MDRJ-]SL5męSN=}TPEETR&'p "Lp!A H*\ȰÇ#JHŋ3jȱǏ  > A $H A $H > A $H A $H | $H A $H A:$H$H A $H AP? ˗H A $H A C}@$/_> A $H A $H | $H A $H A:$H$H A $H AP? ˗H A $H H @'p "Lp@}O@ DPB >QD-^ĘQF=~H$H A $H A ҡ> Aԗ/? A $H A $HIP_|@ $H A $H $A} $H A $H AtH$H A $H A ҡ>˗O? $H A $H A ҡ> B} $H A $H At|/_?ӗ/Q_|@ $@ $@ $@ $? $o ?} '0|/@~ 4/_> H*\ȰÇ#JHŋ3jȱǏ/_|'0?} O ?$H A $H AP Ǐ_>ۗ|O@ ԗ/?$XA .dC%NXE5nGMW0 | | $H A $H A:obӧ߿|˗?}è/_> A $H A $H | $H A $H A:$H$H A $H AP? ˗H A $H A C}@$/_> A $H A $H | $H A $H A:$Hҗ/?$XA .dC%NXE5nGIP_|@ $H A $H $A} $H A $H AtH$H A $H A ҡ> Aԗ/? A $H A $HIP_|@ $H A $H $A} $H A $H AtH$H A $H A ҡ> Aԗ/? A $H A $HIP_|@ $H@ $@ $@r }8`A&TP|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?z$H$H A $H AP? ˗H A $H A C$XA .$/_> H*\ȰÇ#JHŋ3jȱǏ0 <0'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?`> 4xaB O@ DPB >QD-^ĘQF=~? 4xP`|"D ,h „ 2l!Ĉ'Rh"ƌ7r#H 2dȐ!C 2dȐ!C r|B 2dȐ!C 2dȐ!C/!C 2dȐ!C 2dȐ!˧/dȐ!C 2dȐ!C 2dȁ 2dȐ!C 2dȐ!C r|B 2dȐ!C 2dȐ!C/!C 2dȐ!C 2dȐ!˧/dȐ!C 2dȐ!C 2dȁ 2dȐ!C 2dȐ!C r|B 2dȐ!C 2dȐ!C`>} H*\ȰÇ#JHŋ3jȱǏ Cn_>}"E)RH"E)RH"˗A)RH"E)RH"EL/_|OH"E)RH"E)R>} H0O,h „ 2l!Ĉ'Rh"ƌ7r#H H*$|8`A&TaC!F8bE1fԸcGA"̗ ? 4xaB8߿O@ DPB >QD-^ĘQF=~0_˗/? 2dȐ!C 2dȐ!CD/_Hg_>}!C 2dȐ!C 2dȐ B 2dȐ!C 2dȐ!C"̗/F 2dȐ!C 2dȐ!C"̗/F 2dȐ!C 2dȐ!C"̗/F 2dȐ!C 2dȐ!C"̗/F 2dȐ!C 2dȐ!C"̗/$F~Ǐ!C 2dȐ!C 2dȂ`>O@ DPB >QD-^ĘQF=~Y0_'p ,h „ 2l!Ĉ'Rh"ƌ7r#H`>'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?4/_Ȍ˗/dȐ!C 2dȐ!C `|!3˗/߾!C 2dȐ!C 2dȃԨ/_>!C 2dȐ!C 2dȐ _>}!C 2dȐ!C 2dȐ !C 2dȐ!C 2dHiO@ DP‚ H*\Ç#JHŋ3jȱǏӘ> 4xaB O@ DPB >QD-^ĘQF=~,/| A$H A $H A/| AH A $H A rb|Y0_|@ $H A $HӘ$Ȃ$H A $H A/| A̗/? A $H A |4滘/_|cc| $H A $H %˧1|0| $H A $H AJ̗Oc ԧO>߾| /_> H*\ȰÇ#JHŋ3jȱǏӘ"|/߿o_>~O@ ̗/?$XA .dC%NXE5nGiw1_> '0| ̇1_|@ $H A $HӘb|O`c| $H A $H %˧1|'0|߾|$H A $H A)1_>.'P߿O,hp`|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ? ̗Oc> ˗H A $H A Rb|Y0_|@ $H A $HӘ$Ȃ$H A $H A/| o|W1_|@ $H A $HӘ|G1|$H A $H A)1_>_>'0_| /_?70}{/_> A $H A $Hip_O?ǯ߿|/߿˷߿|/?$H0_|8`A&TaC!F8bE1fԸcG˧1~'}O`?~ '0_>'0_>$H A $H A/|70>~O`} '0_>ӗ/_>}$H A $H A)1_>˧o` 70||@}˗H A $H A Rb|=엏@}o`>'P| ϟ|=̗/? A $H A $@|8`A H*\ȰÇ#JHŋ3jȱǏӘ$Ȃ$H A $H A/| =70_|c/_> A $H A $Hi̧2a| $H A $H %˧1B}˗o|/_> />O | 'p$H A $H A/| 䗏߿}/߾/|O`>-̗/? A $H H $@'p  ;80|O`| /_O`?~ 70A <0… :|1ĉ+Z1ƍ;z(0_>/| ̗_70߿| ̷_>[/_> A $H A $Hi̗_>O|/|o_| oa| $H A $H %˧1|˗O?|/_>}O| 'p߾$H A $H A/| K|˗H A $H A D ,@ w;X0_|8`A&TaC!F8bE1fԸcG˧1B k/_> A $H A $Hid| $H A $H AJ̗Oc> ˗H A $H A Rb|Y0_|@ $H A $HӘ$Ȃ$H A $H A/F$XA .<? 4xaB 6tbD)VxcF9vQ`|'p "Lp@ H*\ȰÇ#JHŋ3jǏ`> 4xaB O@ DPB >QD-^ĘQF=~/_G$XAC!‚ H*\ȰÇ#JHŋ3jȱǏ_>} A $H A $H_>} A $H A $H_>} A $H A $H_>} A $H A $H_>} A $H A $H_>} A $H A $H_>} A $H A $H_>} A $H A $H_>} A $H A $H_>8`A&TaC!F8bE1fԸcGA"̗/F 2dȐ!C 2dȐ!C"̗? 4xaB <0… :|1ĉ+Z1ƍ;z!|,h „ 'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?D/@},h „  <0… :|1ĉ+Z1ƍ;z2H9rȑ#G9rȑ#G)_>}#G9rȑ#G9rȑ#˧oȑ#G9rȑ#G9r@9rȑ#G9rȑ#G/#G9rȑ#G9rȑ7rȑ#G9rȑ#G9R|F9rȑ#G9rȑ#G Oȑ#G9rȑ#G9rH9rȑ#G9rȑ#G)_>}#G9rȑ#G9rȑ#˧oȑ#G9H#4H#4H/>$XA .dC%NXE5nG!E Oȑ#G9rȑ#G9rH o,h „ 2l!Ĉ'Rh"ƌ7r#Ȑ80_?$XA .dC%NXE5nG!?O@$XA .dC%NXE5nG!C'P`?$XA .dC%NXE5nG!C˗/_>"E)RH"E)RHOH"E)RH"E)RD~)RH"E)RH"EH"E)RH"E)RH"E)RH"E)RH"E)RH"E)RH"E)RH"E)RH"EP <0…8`A&TaC!F8bE1fԸcGA <0…'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?/dȁB 2dȐ!C 2dȐ! r`>~B 2dȐ!C 2dȐ 90_|B 2dȐ!C 2dȐ 90_|B 2dȐ!C 2dȐ 90_|B 2dȐ!C 2dȐ 90_|B 2d!C 2dȐ 90_|B 2dȐ!C 2dȐ 90_|B 2dȐ!C 2dȐ 90_|B 2dȐ!C 2dȐ 90_|8`A&TaC!F8bE1fԸcG=0@8`A&/_> H*\ȰÇ#JHŋ3jȱǏA1| $H A $H Atb| //1_|@ $H A $H 惘Ϡ>'?~/|O $H A $H A0D _>~߿|/߿/'p ? 4xaB 6tbD)VxcF9vc>`>O| `>'p ? 4xaB 6tbD)VxcF9vc> >~ӷO`'0?}1_|@ $H A $H 0@O?}O`_>~  ̗/?$XA .dC%NXE5nG@,/_> A $H A $HY0_|@ $H A $H  `| $H A $H A:d| $H A $H At$Ȃ$H A $H A0B}/_>ǯ| '0@~~1̗/? A $H A $H/߿}'0_>/@~~8|O@ DPB >QD-^ĘQF=~oa>O`>O`>'|a| $H A $H A:̷0| '0| '0|(߿|? ̗/?$XA .dC%NXE5nG}O`>O`O ? 䗏_| $H A $H Atoa>ӗ/_?#O_>}˧O?'0|˗H A $H A | /| $H A $H At|0_|@ $H A $H  `| $H A $H A:d| $H A $H@ $ <0…? 4xaB 6tbD)VxcF9vc> ˗H A $H A | A̗/? A $H A $H@,/_> A $H A $HY0_|@ $H A $H  `| $H A $H A:d| $H A $H At? 4xaB ˗,h „ 2l!Ĉ'Rh"ƌ7rG$XA .<? 4xaB 6tbD)VxcF9v?} H*\8,h „ 2l!Ĉ'Rh"ƌ7r#8`A&Tp?$XA .dC%NXE5nG2dȐ!C 2dȐ!C 2@ 2dȐ!C 2dȐ!C 9_>}!C 2dȐ!C 2dȐ!CO_Ȑ!C 2dȐ!C 2dȐ2dȐ!C 2dȐ!C 2@ 2dȐ!C 2dȐ!C 9_>}!C 2dȐ!C 2dȐ!CO_Ȑ!C 2dȐ!C 2dȐ2dȐ!C 2dȐ!C 2@ 2dȐ!C 2dȐ!C 9|8`A&TaC!F8bE1fԸcGA)_>}#G9rȑ#G9rȑw_>}#G9rȑ#G9rȑ˗o_A9rȑ#G9rȑ#Gn0@/>$XA .dC%NXE5nG8`A&TH?'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?D0 <0B˧? 4xaB 6tbD)VxcF9v$|BB0@/>$XA .dC%NXE5nG _|O_Ȑ!C 2dȐ!C 2$|BBA 2dȐ!C 2dȐ!C"̗/F 2dȐ!C 2dȐ!C"̗/F 2dȐ!C 2dȐ!C"̗/F 2d!C 2dȐ!C"̗/F 2dȐ!C 2dȐ!C"̗/F 2dȐ!C 2dȐ!C"̗/F 2dȐ!C 2dȐ!C"̗/$F~Ǐ_!C 2dȐB )B )ʗ? 4xaB80?$XA .dC%NXE5nG q|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?4/_Ȍ ? 4xaB 6tbD)VxcF9v|Bfܗ/_|!C 2dȐ!C 2dȐ 1_|B 2dȐ!C 2dȐ!R|B 2dȐ!C 2dȐ!rc}!C 2dȐ!C 2dȐ _Ȑ!C 2dȐ!C 2d|B 2dȐ!C 2dȐ!C$/_Ȑ!C 2dȐ!C 2dȐӘ> 4xaB O@ DPB >QD-^ĘQF=~,/| H*\80,h „ 2l!Ĉ'Rh"ƌ7rc|4 `> A $H A d|4 `>} $H A $H %˧1H$H A $H A)1_>@,/_> A $H A $Hid| $H A $H AJ̗Oc?$H A $H A/|/|$H A $H A)1_>2o~|i̗`> H*\ȰÇ#JHŋ3jȱǏӘ/c|/8˗H A $H A Rb|e̗o`|/߿|$H A $H A)1_>2o`|˗O߿|$H A $H A)1_>2˧O |߿|$H A $H A)1_>4ۗ/>~˗@}i̗/? A $H A |4 `| $H A $H IP| H$H A $H A)1_>*_>'0|ۗ/?$H A $H A/|O@}O`/$H A $H A/|~O`/_| $H A $H AJ̗Oc>o@~_˧/_|8`A <0… :|1ĉ+Z1ƍ;z(0_>,˧o` '0'P_$H A $H A/|7P_}/_}˗| $H A $H AJ̗Oc> ˗H A $H A Rb|Y0_|@ $H A $HӘ$Ȃ$H A $H A/| =70_|c/_> A $H A $Hi̧2_> (0_|8`A&TaC!F8bE1fԸcG˧1B}˗o|/_> />O | 'p$H A $H A/| 䗏߿}/߾/|O`>-̗/? A $H A |4SO`| '0_/| '}oa| $H A $H %˧1|O`>70߿|o`>߿|˗,h „ 2l!Ĉ'Rh"ƌ7r|4K/}ۧO`>~o`O߿| _>˷0_|@ $H A $HӘOa>˧ϟ|O_> ܗ/> 'P_}o| $H A $H AJ̗Oc>%R`> $H A $H A)1_>˗01̗/? A $H A |4[B $H A $H H IP| H ˗H A $H A Rb|'p "Lp|O@ DPB >QD-^ĘQF=~/F}'p "Lp!A H*\ȰÇ#JHŋ3jȱǏ`> 4xaB O@ DPB >QD-^ĘQF=~/_~ Hˇ!B8`A&TaC!F8bE1fԸcGr|@ $H A $H 1r|@ $H A $H 1r|@ $H A $H 1r|@ $H A $H 1r|@ $H A $H 1r|@ $H A $H 1r|@ $H A $H 1r|@ $H A $H 1r|@ $H A $H 1P <0‚'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?D0 <0B8`A&TaC!F8bE1fԸcGA&O@ DPa~'p "Lp!ÆB(q"Ŋ/b̨q#ǎ? )R|F9rȑ#G9rȑ#G Oȑ#G9rȑ#G9rH9rȑ#G9rȑ#G)_>}#G9rȑ#G9rȑ#˧oȑ#G9rȑ#G9r@9rȑ#G9rȑ#G/#G9rȑ#G9rȑ7rȑ#G9rȑ#G9R|F9rȑ#G9rȑ#G Oȑ#G9rȑ#G9rH9rȑ#G4H#4H#4@˧? 4xaB 6tbD)VxcF9vdH7rȑ#G9rȑ#G9R|F9rȑ#G9rȑ#G Oȑ#G9rȑ#G9rH~Ǐ_#G9rȑ#G9rH ,h „ 2l!Ĉ'Rh"ƌ7r#Ȑ'p ,h „ 2l!Ĉ'Rh"ƌ7r#Ȑ!(,h „ 2l!Ĉ'Rh"ƌ7r#Ȑ!˗/H"E)RH"E)RH'RH"E)RH"E)R|D)RH"E)RH"ER̷OH"E)RH"E)R$E"E)RH"E)RH"E)RH"E)RH"E)RH"E)RH"E <0…8`A&TaC!F8bE1fԸcGAP <0…'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?/dȁB 2dȐ!C 2dȐ! r`!C 2dȐ!C 2dB/_>!C 2dȐ!C 2dȏB/_>!C 2dȐ!C 2dȏB/_>!C 2dȐ!C 2dȏB/_>!C 2dȐ!C 2dȏB/_>!C 2dȐ!C 2dȏB/_>!C 2dȐ!C 2dȏB/_>!C 2dȐ!C 2dȏB/_>!CRH!RH!RH!@8`A&Tp`|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?zgq_|y0_|@ $H A $H O}y0_|@ $H A $H 櫨@~ۗ/|]̗/? A $H A $H*;o߾} w1_|@ $H A $H 櫘`|ӷϟ|/_> A $H A $HUGp|o_>~ ? 4/_|8`A&TaC!F8bE1fԸcG=o@~ӷ| ̧@~,˗H A $H A |˷o`>_|ӗ/$H A $H A0H$H A $H A a> ˗H A $H A |d| $H A $H Ato"?}0_|@ $H A $H 曨@~ 'P?~߾|O?~ H |O@ DPB >QD-^ĘQF=~ob>߿|۷o?G1_|@ $H A $H 曘`>o?b| $H A $H A:71} '0~70|$H A $H A a _ '|O`$H A $H A0E~/>} /_~O`$H A $H A!'p "Lp|O@ DPB >QD-^ĘQF=~$Ȃ$H A $H A0H$H A $H A a> ˗H A $H A | A̗/? A $H A $H@,/_> A $H A $HY0_|@ $H A $H  `| $H A $H A:d| $H A $H At$Ȃ$H A $H A!'p "Lp|O@ DPB >QD-^ĘQF=~$Ȃ$H A $H A`> 4xaB O@ DPB >QD-^ĘQF=~O|,h „  <0… :|1ĉ+Z1ƍ;z>$XA .? 4xaB 6tbD)VxcF9v?$XA .$ <0… :|1ĉ+Z1ƍ;z2ȑ$K<2ʕ,[| 3̙4kڼ3Ν<{ 4СD=4ҥL:} 5ԩTZ5֭\z 6رd˚=6ڵlۺ} 7ܹtn ;;PKL̄JJPKr>AOEBPS/img/heter010.gifGIF87aXI?**?***UU?UUU????**?*******?*******U*U?*U*U*U**?*****?*****?*****?***UU?UUUU*U*?U*U*U*UUUU?UUUUUUUU?UUUUU?UUUUU?UUUUU?UUU?**?***UU?UUU?????**?***UU?UUU?????**?***UU?UUU?ժժ?ժժժ???**?***UU?UUU?????***UUU,XI H*\ȰÇ#JHŋ3jȱǏ CIɓ(S\ɲ˗0cʜ_?$XA  <0… :|1ĉ+Z1ƍ;zR| H? 4xaB 6tbD)VxcF9v$DBN/dȐ!C 2dȐ!C ?}!'2dȐ!C 2dȐ!C џ 2dȐ!C 2dȐ!CO_}p'p A Hp <0… :|1ĉ+Z1ƍ;z?}#П8 ?8>'p <0… :|1ĉ+Z1ƍ;z?}O@  P80߿O@ DPB >QD-^ĘQF=~ џ> 'p?O@O@} ߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?O}8~'p }'p>?8`A&TaC!F8bE1fԸcGAB `?8>8P|?} H*\ȰÇ#JHŋ3jȱǏ !G_A p `>ϟ>$XA .dC%NXE5nG#ȯ @O@O@0O,h „ 2l!Ĉ'Rh"ƌ7r#HW?'p @~'p @}O|? 4xaB 6tbD)VxcF9v$D+П8 ?8>'p` <0… :|1ĉ+Z1ƍ;z?}O@  P80߿O@ DPB >QD-^ĘQF=~ џ> 'p?O@O@} ߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?OA~8~'p }'p>?8`A&TaC!F8bE1fԸcGAB `?8>8P|?} H*\ȰÇ#JHŋ3jȱǏ !G_A p `>ϟ>$XA .dC%NXE5nG#ȯ @O@O@0O,h „ 2l!Ĉ'Rh"ƌ7r#HW?'p @~'p @}O|? 4xaB 6tbD)VxcF9v$D+П8}'p |$ϟ~8`A8`A&TaC!F8bE1fԸcG5G_A@'p "Lh0_>$XA .dC%NXE5nnjW?'P ?~ H? 4xaB 6tbD)VxcF9v?}O@ ȏ,h „O@ DPB >QD-^ĘQF=~OA~8~ <0A}8`A&TaC!F8bE1fԸcG1G_A@_}p'p HP? 4xaB 6tbD)VxcF9v?}O@ ȏ߿O@O@p 0O?$XA .dC%NXE5nGW?'P ?~?8`?8}'p |?}8`A&TaC!F8bE1fԸcG1G_A@? O@O@~ P ߿O@ DPB >QD-^ĘQF=~OA~8~߿~(?8 ?'p @}'p`? 4xaB 6tbD)VxcF9v?}O@ ȏ߿O@O@p 0O?$XA .dC%NXE5nGW?'P ?~?8`?8}'p |?}8`A&TaC!F8bE1fԸcG1G_A@ϟ? O@O@~ P ߿O@ DPB >QD-^ĘQF=~OA}8~?(?8 ?'p @}'p`? 4xaB 6tbD)VxcF9v?}O@ ȏ߿O@O@p 0O?$XA .dC%NXE5nGW?'P ?~?8`?8}'p |?}8`A&TaC!F8bE1fԸcG1G>O~ ߿O@O@p 0O?$XA .dC%NXE5nGϟ?  ?? П 8>80߿ <0… :|1ĉ+Z1ƍ;zџ> @'p @~O@O|,h „ 2l!Ĉ'Rh"ƌ7r#F,7П  >8`>> H*\ȰÇ#JHŋ3jȱǏO@ Hp ?~?8`?8}'p |?}8`A&TaC!F8bE1fԸcG3P#H>~?8`?8}'p |?}8`A&TaC!F8bE1fԸcGAgП?o?8`?8}'p |?}8`A&TaC!F8bE1fԸcGAǯ?뷏@ 'p ~o>$XA  <0… :|1ĉ+Z1ƍ;z(@} ߿O@O@~? 4xaBO@ DPB >QD-^ĘQF=~o@'p 'p ~/,h „'p "Lp!ÆB(q"Ŋ/b̨q#ǎ+'p A'p ? П ȏ| H" <0… :|1ĉ+Z1ƍ;z> 4x @ @`?'p }'p |@8`A&TaC!F8bE1fԸcG}o?8`??~O@O@$8?'p "Lp!ÆB(q"Ŋ/b̨q#ǎ+ȏ@ 'p ~/߿߿ `?8>8P|߿| H*\ȰÇ#JHŋ3jȱNJ>7П ߿(?'p @~'p @}O|? 4xaB 6tbD)VxcF9vX1G~W?8?~O'p?O@O@} ߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ+ȏ@ 'p ~/߿O@ p `>_>$XA .dC%NXE5nc|_AO@~?~ П8 ?8>'p` <0… :|1ĉ+Z1ƍ;zo?~ H A~?8`?߿'P @O@O@0/,h „ 2l!Ĉ'Rh"ƌ7rb>/_}$H?~?8`?߿'P @O@O@0/,h „ 2l!Ĉ'Rh"ƌ7r"@}̗O@,X@ ߿(?'p @~'p @}O|? 4xaB 6tbD)VxcF9vȑ_>}  ߿'P @'p ?~? O@  P80߿O@ DPB >QD-^ĘQF=jO_?8`A~g ?ۗ߿'P @O@O@0/,h „ 2l!Ĉ'Rh"ƌ7r1c|8`AO~ o߾|?8~'p }'p>߿8`A&TaC!F8bE1fԸcGO@ ? 4H0A~8~'p }'p>߿8`A&TaC!F8bE1fԸcG'p  O@ G_A p `>_>$XA .dC%NXE5nGO@ H|?8~'p }'p>߿8`A&TaC!F8bE1fԸcG/O@$8`>'p?O@O@} ߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?Ϡ?Ǐ߾|O@  P80߿O@ DPB >QD-^ĘQF=~/AǏ}+П8 ?8>'p` <0… :|1ĉ+Z1ƍ;z ?G}ӧO_@ `?8>8P|߿| H*\ȰÇ#JHŋ3jȱǏ'p>$X0߿O@ p `>_>$XA .dC%NXE5nG HP`>$X`|?8~'p }'p>߿8`A&TaC!F8bE1fԸcGP _>$XA .dC%NXE5ndž `?8>8P|߿| H*\ȰÇ#JHŋ3jȱǏ )0A~8~'p }'p>߿8`A&TaC!F8bE1fԸcGR`> 'p?O@O@} ߿'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?6|O@  P80߿O@ DPB >QD-^ĘQF=~lȏH+П8 ?8>'p` <0… :|1ĉ+Z1ƍ;zؐ?W?'p @~'p @}O|? 4xaB 6tbD)VxcF9v!?~ O@ ?~ П8 ?8>'p` <0… :|1ĉ+Z1ƍ;zؐ>/>~$H`@ `?8>8P|߿| H*\ȰÇ#JHŋ3jȱǏ 'p|O@ ߿(?'p @~'p @}O|? 4xaB 6tbD)VxcF9v?}~,h0߿߿ `?8>8P|߿| H*\ȰÇ#JHŋ3jȱǏП 4߿߿  P80߿O@ DPB >QD-^ĘQF=~O?'p  O}p'p A Hp O@ DPB >QD-^ĘQF=~~,h`| H" <0… :|1ĉ+Z1ƍ;z(@},h| H" <0… :|1ĉ+Z1ƍ;z2b>!' 2dȐ!C 2dȐ!C/@}G A} 8> WP`} H*\ȰÇ#JHŋ3jȱǏ ''p| ׏?~ӧO߾}ׯA$? 4xaB 6tbD)VxcF9v$} ׯ_?~(~?O@ DPB >QD-^ĘQF=~?8_?~۷O>}Ǐ_~7p ,h „ 2l!Ĉ'Rh"ƌ7r#H'p 8p @},80?$XA .dC%NXE5nG ɐ!C 2dȐ!C 2dȅ8@$XA 'p 8`A&TaC!F8bE1fԸcG=П <0…O@ DPB >QD-^ĘQF=~H $H A $H AtH $H A $H AtH $H A $H AtH $H A $H AtH $H A $H AtC$XA 'p A'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?z/!?}8`A&̗o? 4xaB 6tbD)VxcF9v#@}̗o@,h „˗>Ǐ?$XA .dC%NXE5nǍ (p_}8`Aϟ?~O~ӗ/>~8`A&TaC!F8bE1fԸcG;˧@,h „ /߾~ H*\ȰÇ#JHŋ3jȱǏϟ?$XA ߾|8@ <0… :|1ĉ+Z1ƍ;zh_>$XA ? 䗯,h „ 2l!Ĉ'Rh"ƌ7r| H*4,_> H*\ȰÇ#JHŋ3jȱǏ8`A&Tx? ,h „ 2l!Ĉ'Rh"ƌ7r#Ȑ"7rȑ#G9rȑ#GH9rȑ#G9rȑ#GfԗOd?~7_|F9rȑ#G9rȑ|۷/_>}9rȑ#G9rȑ#Gn̗/_ׯ_?oȑ#G9rȑ#G9rc|_|(?O@ DPB >QD-^ĘQF=~`>8`A O,h „ 2l!Ĉ'Rh"ƌ7r#ȋ8p,hP`>} ? <0… :|1ĉ+Z1ƍ;z"| O@ `?߾|'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?`>O@ ۗ/}O_>}'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?0'p ۧ/_|O@ DPB >QD-^ĘQF=~џ?ϟ!C 2dȐ!C 2dȐ /dȐ!C 2dȐ!C 2dH2dȐ!C 2dȐ!C 2@ 2dȐ!C 2dȐ!C R| 2dȐ!C 2dȐ!C )_|B 2dȐ!C 2dȐ!Cf| 2dȐ!C 2dȐ!CT菟>}COBKo>} 2dȐ!C 2dȐ!CԸ`>O@ _|`>O@ DPB >QD-^ĘQF=~Q|@7p| `> O@ DPB >QD-^ĘQF=~iQ|(?˗o@8`>  <0… :|1ĉ+Z1ƍ;zb?o@}o> /˗~ ? 4xaB 6tbD)VxcF9vD}o |?(0_|˗_| <0… :|1ĉ+Z1ƍ;zr"|o@'߿|(? 4xaB 6tbD)VxcF9vD ?|O G߿? 4xaB 6tbD)VxcF9vdD ?ϟ@}O 7P߿~G0?$XA .dC%NXE5nG80߿? ϟ@~o#? 4xaB 6tbD)VxcF9vD} O'˗O`|˗/>$XA .dC%NXE5nG'p?O>'P|뗏?~? 4xaB 6tbD)VxcF9v$E} @ /_>}˗o_|̗/_˗O,h „ 2l!Ĉ'Rh"ƌ7r#H8`? /(O@8`A&TaC!F8bE1fԸcGAb0'p| /_| |  <0… :|1ĉ+Z1ƍ;zR?~|̗/_>~ ӧO?!C 2dȐ!C 2dȐ!˗O_~2dȐ!C 2dȐ!C 2|ܗ/!C 2dȐ!C 2dȐ˧`|B 2dȐ!C 2dȐ!Cf/ 2dȐ!C 2dȐ!C _|2dȐ!C 2dȐ!C 2|%2dȐ!C 2dȐ!C 2| 2dȐ!C 2dȐ!C )@ <0… :|1ĉ+Z1ƍ;z27rȑ#G9rȑ#G9|9rȑ#G9rȑ#G/_>}#G9rȑ#G9rȑ#˗O}1|9rȑ#G9rȑ#GFO@8_~G A/| O@ DPB >QD-^ĘQF=~Y|O>~˗@~|?˗?}'p "Lp!ÆB(q"Ŋ/b̨q#ǎ?,0'p|?o?O ?_ '0,h „ 2l!Ĉ'Rh"ƌ7r#H80 GP`_O ?_ '0,h „ 2l!Ĉ'Rh"ƌ7r#ȃ ?GПǏ_O@?}(߿| H*\ȰÇ#JHŋ3jȱǏ ˗/_>} 'П~ |_>}G0@O ? 2dȐ!C 2dȐ!C"ԗ/_> ˗O_?˗O>~_>W0@~ӗ/? 2dȐ!C 2dȐ!C/!C 2d!C 2dȐ!/dȐ!C 2dȐ!C 2dȁ 2dȐ!C 2dȐ!C 2dȐ!C 2dȐ!C 2dȐ!C 2dȐ!RH!A8`A&T!B$XA .d0!@,h „ 2D <0… :|1ĉ+Z1?8`A"ܗ0a„'p "Lp!ÆO@ DPB'p "Lp!ÆB(q"Ŋ/b_Ɖe/cƌ˘1c~3f̘1cƌ3fx_Fe_ƌ'˘1C2f̘1cƌ3f̘b? H ˗0a„,h „ 2l8A$XA .dH߿'p "Lp!ÆB(q"Ŋ/boeto3N7_ƌ/cƌ3f̘1cƌ-/D/cƌ 1cF˘1cƌ3f̘1cF_ 1cƉ˘1#Be̘1cƌ3f̘1Ee/_F˘1De̘2f̘1cƌ3f̘Ѣ?,'p 4h ?$X@ H*\Ȱ@9tСÆsСC:tСC:tСC!B}:珟sСCϡC8`A(@ H*\Ȱ#JHŋ-Ϣ{o3N'_ƌQW@3f̘1cƌ3fhџ@eCe̘q?2f4˘1cƌ3f̘1cF/D/cƌ 1A}7_ƌ3f̘1cƌ3Z'ПE}/?=7_ƌ'/cF(+o3f̘1cƌ3fO?2ܗ_| @3fO ꣨2f̘1cƌ3f̘Ѣ?O@ w_><@}@3fO ꣨2f̘1cƌ3f̘Ѣ?,h_|3Ce̘q?2f4? 4xaB 6tbD)VxEYԗ`>g˘1DehPE} 1cƌ3f̘1cƌ gQ_F/A/cƌ 1A}7_3f̘1cƌ3Z'ПE} ˧O?}{o3N'_ƌQW@3f̘1cƌ3fhџ@e=7_8`>~ H*'ПB *4OB}  <0… :|1ĉ+ZѢ?,h_|3Ce/_}˗/_>3'_ƌQW@3f̘1cƌ3fhџ@e} @˧_|˗/߾ 诠?$X`?$XA}W@ H*\ȰÇ#JHŋ-Ϣ{o?˷ϟ|'P ,h ‚'_A&_„ KPO@ DPB >QD-^hџ@e$> O@8p8p'p`>~ <`|'_A&_„ KPO@ DPB >QD-^h~e菟C`>7p?$XA˧B/a%L🾄 #@ H*\ȰÇ#JHŋ-#П  <8?O@(8p ? 8`AO@}8׏ӷO@  ϟ?'p "Lp!ÆB(q"Ŋ/b/A&/_|0@},h B̷? ('p`} ,h𠾃 ;(,h „ 2l!Ĉ'Rh"F2x?}og0_|0 <O@0?$XA}'P G? H*\ȰÇ#JHŋ-#П  }8`A8P? 7 0o߿'p ;ȏA7,h „ 2l!Ĉ'Rh"F/|@O8?˗_ ̗/_>} '_AO}(?8`A0@ OO@ DPB >QD-^hџ@e4؏B/#}˧C~c|%'_A'p?~ ?~ HwO@ DPB >QD-^hџ@8p  <8`>8o?$XA ˗/_>} O?O |߿߿8 $@~ 8`A&TaC!F8bE1Z'C ԗQ?~ 1#}/cB|o_> ?~$HP>8?#@ H*\ȰÇ#JHŋ-?x_>}@3/_|2"'_A˗/_ O@~? A$H A}? 4xaB 6tbD)VxП? O}ϟ?$XA gB ԗ0aB˧A7_„ &L8P_|K0!AO|3/_|'_B C/~7_„ &D?~O@ ? 4xaB 6tbD ӧ`>'p@o? H A}"<߿|A'p "Lp |O@ O 0#?8`A/_>}+o}/?ӗ/_|IlO?Il߿|8`A&TP,h?o |O@ w0;~;xp?ӗ/_|O@ DPB >1a}ǯ? ۧ/_>}ILO?Il/>}8`A&T,hР? 7|߿'p 38P/ ϠA 菟|ϠA O_|O@ DPB > |'QbA~OAI$O}g(QD W?'p~,(0_| g߾|g🾂3hРA˗O? 4h ~˷,h „ 2l!ć˷_Ĉ ˗_DXP_ĆOA/bĈ#&'_A ۗ/_>} 1_|+|;"F/_~#6/_>}"F1bĈ˗_Ĉۗ/  /_| @#F1? Q?~8PO#8P#H A /~ H/> *TPB *T|)TPƒSП@  ԧPa|_>),o?  ܗ/> SPaBOaB HGp> G A /> H*/_>~ .\p… .\_>}.\p!A~[xП@ [`> g pa|oa| .4O-D`> 4hP?} `>'p?} A $(P_>~ H*,/߾ .\p… .D/ .\x_>} oB} _>~3B[~'_|/_> .O-D> 0Oӷ߾|G🿁$H A <0ƒ[p… .\pƒ-\p„뷰?.Էp}/?-$o 3_>~}_>.\ϟ@[8߿O˗O7A $H_~ H*L/ .\p… .,/ .\_~ oB} "ԗo?㷐.D` /@'… 诠?~ `|3`>wP_A-\h0߾ .\0> .\p… .\Hp_ .\_}'….\ p!B}/~/_A "D!B"D!BC!B"o? A}"Dp?~!B'П~ |_>}!B W??~;/_~W@"/?"D!B!B"D!B"Dx0_>"D!BA!DhPB/?!<O@ o_| '_|/_~ӗ/?"O!D8?ԇp ?7B!B"DP|!D!B"D!B̗B"D?~Р?"4!B/>!!D!B"D!Bԗ/B"Da|Р?"4!B/߿| 7,h „ 2l8П@sX?̗/?7ПÆСCϟ?:tСC˧ϡC ˧O>!B}O߾ 🿁:tСC+菟Â-Ǐ~ !O_| +o? ۗCܗ_>9tСC:D|9t@~ӷϟ?sPCo>9o?70C诠?~ |$菟|#O#H AO_} H*$/_>~o… .\p… ϟ|.\p?O>'….\(?-$o ̗o`>.\П@;ϟBO@8P>˷|#@ $H@˗,h „ ˗~p… .\p…/_}.\`?}ϟ}-O -\P?~ o…'0@~/ '_A˗0'p@}G@} A /@ <0}_|SPB *TPB+/_>}*TР?~П@ O@ W`,X`(P7p  K0a‚#Bǯ?~˗@˧>OB} 0aB ӗ/? &L_}O~'p "Lp!Æ:`|"ă˗O_?o@$H@$XР?} 80_? $H>O@,h B/߿|/a„ П@'p@˗/A8_|㗏߿~o@} /?7p?} ߿8`A;o_|;x˗/>/@$XA .dC)/_|_?~˧@ԷO $` +H ,? ,H_ ,Xp`>0@O@ DXB˗o_? Ϡ|/߾˗A}/?K/a„%o_|/a„ۗ/_>}'p~'p "Lp!Æ:ǯa?~˗O>~s_?~˗/_>}'p O@,X`A} 'p ,X_>4h? 4hP`>@~3hРA 3(?3H? ߿O@}O|7p@ HA4߾|ӧo?~<?~˗/}8~'p "Lp!Æ:?0+X0}П ӷO $` +X`'P ?o? 4x|O_|0a„!`|g? ߿O@}/ O'p  w AO@ ԧ?'p O@ DPB >tDO@8`A O@,X`A} ˧_ $@$@8`A&TaÁw0}3菟A?8P˗/_? O? ? 4h_@~ϟ?П 7? 4xaB 6tС>~!BП ӷO $` +H_|+X}W?~ H O@ DPB C|Ϡ?~˗o?} ̗/_>~ ?ϟ'p  wП 7? 4xaB 6tС>~!BП ӷO $` +H0+X}W?~ H O@ DPB CA~˧Ϡ?~˗o߿~/_| O,XP?gРA3hРA $П 7? 4xaB 6t>~!BП ӷO $` +H0+X|@$@8`A&TaÁ簠?~˗~˷?O@ ϟ 4hp| 4hРA8`~'p "Lp!Æ:"D8`A O@,X`A} ˧O?} @~ ? O@ H*\Ȱ@;O?C0O@8`gПA ϠA 4h @,/@$XA .dCAq @,O> H ,`}W`˗o_,X?$XA .dp?/_| P| $/~ #H? $Hp| HO@ <0… :|P?!O@'? W`$_ /߾+X A H*\Ȱ@C߾| 㧰|O˧A} 9l/C'p O@ DPB >tD'p  +X` ̗/? /~W`A8`A&TaÁw0_>}ϡC}_s_>*O@ <0… :|P?!O@'? W`,菟| ,_|+  <0… ǯA:w0;/? sСB$X_ H*\ȰÇ@$XП}8 A ,XP_˗`_+X A H*\Ȱ@Ko_|sP}6ϡC 8`~'p "Lp!Æ:"D8`A O@,X`A} ˗o_ _ ǯ`'p "Lp!Æ!|g?!ܗ/>%簡|:TП 7? 4xaB 6tС>~!BП ӷO $` +Hp_ ܗO>~ ǯ`,X`A H*\( Ǐ@}$? $H> $ $H 'p "Lx? o ,h „ 2lC} B8? o@$H_ W`~ ,o_|_ +X`'p "Lp~ (?׏@$H AO@ OA$H AO@ D @,/@$XA .dCAq @,O> H , ~ ,X|'p?~8p? HA'p "Lp}?˗/>~˗߾|/_>~˗߾|/_>~$H>O@  <0A$X_ H*\ȰÇ@$XП}8 A ,XP_A  A 4ϟA /_|8`A&T_~~8_>GP?~O?ϟ@ ?} ȏ A} O@ ? 4xaƒ H`|8`A&TaC"ā H?}'p A ,Xׯ`, W` ˗/_>} ,X` @ _ ǯ` WP |WP,X`A,X` ,(? o ,h „ 2lC} B8? o@$H_ W |W`,_ +X`˗/_~ ,X` @ ܗO>~ ǯ` WP`> A ,XP| ,X` O@ <0… :|P?!O@'? W`$߿|,X|'p?~8p?(_|8po 7p8P?~/_>}? 4xP|wPA `_A+ ,8P_A˗O_A W`W` ,X@$X_ H*\ȰÇ@$XП}8 A ,XP_AO_˗/>~W`A ܗ/_>~ ,8_|+Xp_?Ǐ?~/_>/+88P7p@ӷ8P |8🾁O@ <8? o ,h „ 2lC} B8? o@$H_ W|+X|? ,H_(,hp?}wP`>ϟ>_`AwPA`>O$H>#H A <0A$X_ H*\ȰÇ@$XП}8 A ,XP_O_/߿|W`AO@ H ?#(0߿|/@'A$A Ǐ } H Gp`|Gp>#H A <0A$X_ H*\ȰÇ@$XП| H~ HA_|<(p_>}3O~>}O~ 0 <>o?O?~(`>'p  ǯ~˧? /_>~˗_A o~ W ,(_ ,X`'p O@ DPB >tD'p ۷ ?  $`>~/˧ϟAǏ~?~o ?$XA_|߿|__>}? Wp?~_}WP`|#/_| WP`WP,X`A,X` ,(? o ,h „ 2lC} B8? o@$H_ WP`> W`W`A O} H(߾|O |O_|/_>~o@ /?~8˗/?~ (8?}7p?} 4/ H HA8_~/A 'p`>@,߿8߾| <0… П@'p?~˧@8`>8P> П 4/ H ,}/ ӧO>}ǯ`$/_>~ H*\p?54菟|G|O@}o 8,hР| H ,` @#_ +X`'p`~ HA wǯ`|˗A 'pO@}O@ $H 'p "Lx? o ,h „ 2lC} B8? o@$H_ W` /_|#_ +X`'p} H w_ ; >ܗ/_}'0_|wA};xA ,_>O ? ,H_W_+(p_| /_| W|O A /,h „8`~'p "Lp!Æ>"D8`AO@ O@ ˗O? ܷO>}П ?$X A̷_?8`/߿|ϠA O~(p_~7p?~ (P|П'P}ۧo8߿8`A;xO@ <0… :|P?!O@ gРA߿|4H0|3h? 4`>GP ,X0@}O@'p 菟A 8| |#H? $Hp| HO@ <0… :|Q?!O@ gРA߿|4H0?ϠA4h ?O H`|O?gР }g?~ ӗO>~ +`>ϠAgРA 4H? ? 4xaB 6t?}"FП ? ϠA38p_>}3h |g? gРA8🿁O@ /?'0? 3(? ϠA +/_?3O 4hp| 4hРA8`~8`A&TaC!/bĈ H?}8` 4h>˧ϟA˷? 4ϟA O@~ ? 4xa„0?~ "g`>'p?} G A ? 4xaƒ H`| H*\ȰÇ1bD$XП>~ H? 4O (? A4h? 0@ (? 4xa„0?~ "wp_|!ԗПBSPB8`~8`A&TaC!/bĈ H?}8` 4h> 4?3h? 4`>80?$XA C菟„)TPBS| *TP @,/,h „ 2l!E? ,@$XР?} H@~ $`>8?$X߿'p  ˗/80,h „ O~8`A'p}$HП>$ 8߿8`A;xO@O@ DPB >O#'p O@3hР ߿| ,/~gР 4hP>$,h „ !OaB˗OƒK/? ˧PB 'p 'p "Lp!ÆBo_Ĉ8`A'p 4h?}70A˗O?4h? `>O@ DP?[˗OBK/ ˷p…8`}8`A&TaC!ۗ/bĈ H |8` 4h>/A_>4h? $o|O@ DP@['P>$XP>'P G? $H |8`A&4П  <0… :|_|"FП  gРA/_|4H03菟A3hРA4hРA 4ϟA4h?~O@ #Hp>#H A  <0A$H_>~ H*\ȰÇ/bć H|8`A 4h>˧ϟAӧ>4h?$XA .dp?9,?$XРA} /A$A $H_} HO@O@ DPB >H0_>#:O@ gРA4hРAϠ?~ ? 4xaB 6?~ '| O@'p?~ $H A <0!A$8P_> H*\ȰÇ ˗_Ĉ 8@}'p  O@ ˗/> GA'p ? 4xaB 6o @ ϟ?'P>$XP>0 O@,h}C!B8?~O@ DPB >xp_>}"F\П? ,ϠA380}3h`> gР8`A&TaÁw?~ |s8PCsp`|9t @/>$XA .dC ˗_Ĉ 8P|'p ;x A}o߿|O@} ,h „ 2l8B O|(˧o 7p 7p@ H˷!BO@? 4xaB 6tb~/bD O_|'p ;x A}/_>} /~;x}IT?}ϟD$ԗ0_?_>IOD%?˧ϟ@˗o?~;`(q?~˧o?/_|(QD%J_?~˗/>}O@ ϟ~0@O@ $!B!׏B_>!D8B"D!B C菟|/>˗@"DHP|wP"D?0@?o@~ӗ/_| <0… :|1"Do>} H A} <🿁 HA8p |'p ӧ>'p ? 4xaB 6o @_|0? 4xP/_|П <?۷O>$X}O@ DPB >QA ϟ?$XA%LxP_„ ˗O?%L_„ &L0a„!| '> ?$XA}˗o wO@ o@'p "Lp!ÆB(q@$ <0aA ԇ߾|S0?~ SPB *THB˗/~0@ < | O? 4xa„ H,h „ 2l!Ĉ'Rh08 A 8p'p "Lp!Æ!| ̗/@ ?$XA}80> 8`A&TaC!F8bE1ZQA} OC 8p'p "Lp!Æ!_|/_>˷O?~Kȏ?sСC:tСC:tСCsP|9O?~ sСCC菟|/˗@:wsСC:tСC:tСCsP|9O?~ sСCC菟~7_|菟C O| OA'p "Lp!ÆB(q"Ŋ/bo @,hП>/_?#H@'p ? 4xaB 6o @߿} H0߿П <?8P П <0… :|1ĉ+ZѢ'p?$H`>'p?~8p? H*\Ȱ@#`>߿'p ;xР'p "Lp!ÆB(q"Ŋ/b//#A&˘1D3/_|3_Ɓ(K/cƌ3f̘1cƌ-˨/D&˘1D_Ɓ(K/cƌ3f̘1cƌ-˨/D&˘1D_Ɓ(K/cƌ3f̘1cƌ-˨/D&˘1D_Ɓ(K/cƌ3f̘1cƌ-˨? 4xA~8`A8`A&TaÁO@ O@ O@ O8`A&TaC!F8bE1Z@~,h B8`A8`A&TaÁ:tСC:tСC:tСC:tСC:tСC:tСC:"tСC:tСC:tСC:tСC:tСC:tСC:tСC:tСC:tСC:tСC:tСÂ9tСC 9tСCsСC:tСC:tСCsСC СC*СCϡC:tСC:tСC:t诟C:t8_?r!_?$XA .d_ 6lذaÆ 6lذaÆ 6lذaCO@ DPBO@ DPB ? 4xaB ? 4xaB 6tbD)VxcF4jXПF/ӨQcA5jԨQF5jџF ӨQE5j,OF5jԨQF#ӨQcA5jOFiԨQF5jԨQcD5j,OFiԨ?5jԨQF5jOFiԨ?5QF5jԨQFiԨ?5^QƂ4jԨQF5jԨ1"@,h „ 24? 4xaB 6TП <0… O@ DPB >QD-^ĘQF=~RH%MDRJ-]SL5męSN=}TPEETRM>UTU^ŚUV]~VXe͞E4 ;;PK3Sh݂PKr>AOEBPS/img_text/heter010.htm* Description of the illustration heter010.eps

The image heter010.gif shows the Gateway Process Flow and is described in the text preceding and following the image.

End of image description.

PKZ/*PKr>AOEBPS/img_text/heter006.htm Description of the illustration heter006.eps

The image heter006.gif shows heterogeneous connectivity process architecture as three components:

  • The Oracle database, including the Heterogeneous Services module

  • The agent, which includes agent generic code and a driver

  • The non-Oracle system

End of image description.

PKv85PKr>AOEBPS/img_text/heter002.htmv Description of the illustration heter002.eps

The image heter002.gif shows the client application accessing multiple non-Oracle instances. A client application is sent to Oracle Database and goes through multiple agents to access multiple non-Oracle systems.

End of image description.

PK=@PKr>AOEBPS/img_text/heter005.htm/ Description of the illustration heter005.eps

The image heter005.gif shows a client accessing non-Oracle databases that reside on the same computer as the Oracle databases using Heterogeneous Services. The image is described in the subsequent text.

End of image description.

PK-[4/PKr>AOEBPS/img_text/heter008.htm' Description of the illustration heter008.eps

The image heter008.gif shows a flow diagram of passthrough SQL for queries and is described in the preceding text.

End of image description.

PKA/,'PKr>AOEBPS/img_text/heter011.htm_ Description of the illustration heter011.eps

The image heter011.gif shows multithreaded agent architecture. Two user sessions on the Oracle server (which includes Heterogeneous Services) issue requests to two dispatcher threads, which are part of the agent process. The agent process consists of dispatcher threads and task threads. Each dispatcher thread relays the requests by means of a task thread to the non-Oracle system. Individual requests are relayed by the dispatcher in one of two ways:

  • A single request from a user session is relayed to the non-Oracle system over a single task thread set up by a single dispatcher.

  • Requests from different user sessions are relayed to the non-Oracle system by a task thread that is shared between the two dispatchers.

End of image description.

PKld_PKr>AOEBPS/img_text/heter009.htm Description of the illustration heter009.eps

The image heter009.gif shows the data transfer process. The components are the client application, Oracle Database, the agent process, and the non-Oracle system. HS_RPC_FETCH_SIZE and HS_FDS_FETCH_ROWS parameters are set to optimize the transfer. The data transfer process is described in the text preceding the image.

End of image description.

PKPPKr>AOEBPS/img_text/heter007.htm$ Description of the illustration heter007.eps

The image heter007.gif shows a flow diagram of nonquery passthrough SQL and is described in the preceding text.

End of image description.

PK ,)$PKr>AOEBPS/img_text/heter004.htm Description of the illustration heter004.eps

The image heter004.gif shows a non-Oracle system on a computer that is separate from the Oracle system. The image is described in the subsequent text.

End of image description.

PK]PKr>AOEBPS/cvrspine.htm Oracle® Database Heterogeneous Connectivity User's Guide

Oracle® Database

Heterogeneous Connectivity User's Guide

11g Release 2 (11.2)

E11050-01

Oracle® Database

Heterogeneous Connectivity User's Guide

11g Release 2 (11.2)

E11050-01

PKZPKr>A OEBPS/toc.ncx " Oracle® Database Heterogeneous Connectivity User's Guide, 11g Release 2 (11.2) Cover Table of Contents List of Figures List of Tables Oracle Database Heterogeneous Connectivity User's Guide, 11g Release 2 (11.2) Preface What's New in Heterogeneous Connectivity User's Guide? Introduction The Role of the Heterogeneous Services Component Features of Oracle Database Gateways Using Heterogeneous Services Agents Performance Recommendations Index Copyright PK$a PKr>AOEBPS/content.opf} Oracle® Database Heterogeneous Connectivity User's Guide, 11g Release 2 (11.2) en-US E11050-01 Oracle Corporation Oracle Corporation Oracle® Database Heterogeneous Connectivity User's Guide, 11g Release 2 (11.2) 2009-07-31T22:45:58Z Describes Oracle's approach to information integration in a heterogeneous environment. Describes Oracle Database Gateways and is a user's guide for these Oracle products. PK*LJPKr>A OEBPS/lof.htmS List of Figures PK?tձPKr>AOEBPS/dcommon/prodbig.gif GIF87a!!!)))111BBBZZZsss{{ZRRcZZ!!1!91)JB9B9)kkcJJB991ssc絽Zcc!!{祽BZc!9B!c{!)c{9{Z{{cZB1)sJk{{Z{kBsZJ91)Z{!{BcsRsBc{9ZZk甽kBkR!BZ9c)JJc{!))BZks{BcR{JsBk9k)Zck!!BZ1k!ZcRBZcZJkBk1Z9c!R!c9kZRZRBZ9{99!R1{99R{1!1)c1J)1B!BJRkk{ƽ絵ތkk絵RRs{{{{JJsssBBkkk!!9ss{{ZZssccJJZZRRccRRZZ))cBBJJ99JJ!!c11991199Z11!c!!))Z!!!1BRck{)!cJBkZRZ,HP)XRÇEZ֬4jJ0 @ "8pYҴESY3CƊ@*U:lY0_0#  5tX1E: C_xޘeKTAOEBPS/dcommon/doclib.gif GIF89a1֭Μ{kc{JsBc9Zs1Jk,@Iv 5a-5-vasEnq0& ҈VF[|O @@48۪pM(7*X(ƙjo0Fq|uHu9(dK@ @Y ! mFt,gNh% NN@ F˿lN du_g%;PKY@ PKr>AOEBPS/dcommon/oracle-logo.jpgfwJFIFC    $.' ",#(7),01444'9=82<.342C  2!!22222222222222222222222222222222222222222222222222'7" }!1AQa"q2#BR$3br %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz w!1AQaq"2B #3Rbr $4%&'()*56789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz ?( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( (QEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQE!KEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEzE7V%ȣOΏ9??:a"\fSrğjAsKJ:nOzO=}E1-I)3(QEQEQEQEQEQEQE֝Hza<["2"pO#f8M[RL(,?g93QSZ uy"lx4h`O!LŏʨXZvq& c՚]+: ǵ@+J]tQ]~[[eϸ (]6A&>ܫ~+כzmZ^(<57KsHf妬Ϧmnẁ&F!:-`b\/(tF*Bֳ ~V{WxxfCnMvF=;5_,6%S>}cQQjsOO5=)Ot [W9 /{^tyNg#ЄGsֿ1-4ooTZ?K Gc+oyڙoNuh^iSo5{\ܹ3Yos}$.nQ-~n,-zr~-|K4R"8a{]^;I<ȤL5"EԤP7_j>OoK;*U.at*K[fym3ii^#wcC'IIkIp$󿉵|CtĈpW¹l{9>⪦׺*ͯj.LfGߍԁw] |WW18>w.ӯ! VӃ :#1~ +މ=;5c__b@W@ +^]ևՃ7 n&g2I8Lw7uҭ$"&"b eZ":8)D'%{}5{; w]iu;_dLʳ4R-,2H6>½HLKܹR ~foZKZ࿷1[oZ7׫Z7R¢?«'y?A}C_iG5s_~^ J5?œ tp]X/c'r%eܺA|4ծ-Ե+ْe1M38Ǯ `|Kյ OVڅu;"d56, X5kYR<̭CiطXԮ];Oy)OcWj֩}=܅s۸QZ*<~%뺃ȶp f~Bðzb\ݳzW*y{=[ C/Ak oXCkt_s}{'y?AmCjޓ{ WRV7r. g~Q"7&͹+c<=,dJ1V߁=T)TR՜*N4 ^Bڥ%B+=@fE5ka}ędܤFH^i1k\Sgdk> ֤aOM\_\T)8靠㡮3ģR: jj,pk/K!t,=ϯZ6(((((((49 xn_kLk&f9sK`zx{{y8H 8b4>ÇНE|7v(z/]k7IxM}8!ycZRQ pKVr(RPEr?^}'ðh{x+ՀLW154cK@Ng C)rr9+c:׹b Жf*s^ fKS7^} *{zq_@8# pF~ [VPe(nw0MW=3#kȵz晨cy PpG#W:%drMh]3HH<\]ԁ|_W HHҡb}P>k {ZErxMX@8C&qskLۙOnO^sCk7ql2XCw5VG.S~H8=(s1~cV5z %v|U2QF=NoW]ո?<`~׮}=ӬfԵ,=;"~Iy7K#g{ñJ?5$y` zz@-~m7mG宝Gٱ>G&K#]؃y1$$t>wqjstX.b̐{Wej)Dxfc:8)=$y|L`xV8ߙ~E)HkwW$J0uʟk>6Sgp~;4֌W+חc"=|ř9bc5> *rg {~cj1rnI#G|8v4wĿhFb><^ pJLm[Dl1;Vx5IZ:1*p)إ1ZbAK(1ׅ|S&5{^ KG^5r>;X׻K^? s fk^8O/"J)3K]N)iL?5!ƾq:G_=X- i,vi2N3 |03Qas ! 7}kZU781M,->e;@Qz T(GK(ah(((((((Y[×j2F}o־oYYq $+]%$ v^rϭ`nax,ZEuWSܽ,g%~"MrsrY~Ҿ"Fت;8{ѰxYEfP^;WPwqbB:c?zp<7;SBfZ)dϛ; 7s^>}⍱x?Bix^#hf,*P9S{w[]GF?1Z_nG~]kk)9Sc5Ո<<6J-ϛ}xUi>ux#ţc'{ᛲq?Oo?x&mѱ'#^t)ϲbb0 F«kIVmVsv@}kҡ!ˍUTtxO̧]ORb|2yԵk܊{sPIc_?ħ:Ig)=Z~' "\M2VSSMyLsl⺿U~"C7\hz_ Rs$~? TAi<lO*>U}+'f>7_K N s8g1^CeКÿE ;{+Y\ O5|Y{/o+ LVcO;7Zx-Ek&dpzbӱ+TaB0gNy׭ 3^c T\$⫫?F33?t._Q~Nln:U/Ceb1-im WʸQM+VpafR3d׫é|Aү-q*I P7:y&]hX^Fbtpܩ?|Wu󭏤ʫxJ3ߴm"(uqA}j.+?S wV ~ [B&<^U?rϜ_OH\'.;|.%pw/ZZG'1j(#0UT` Wzw}>_*9m>󑓀F?EL3"zpubzΕ$+0܉&3zڶ+jyr1QE ( ( ( ( ( ( ( (UIdC0EZm+]Y6^![ ԯsmܶ捆?+me+ZE29)B[;я*wGxsK7;5w)}gH~.Ɣx?X\ߚ}A@tQ(:ͧ|Iq(CT?v[sKG+*רqҍck <#Ljα5݈`8cXP6T5i.K!xX*p&ќZǓϘ7 *oƽ:wlຈ:Q5yIEA/2*2jAҐe}k%K$N9R2?7ýKMV!{W9\PA+c4w` Wx=Ze\X{}yXI Ү!aOÎ{]Qx)#D@9E:*NJ}b|Z>_k7:d$z >&Vv󃏽WlR:RqJfGإd9Tm(ҝEtO}1O[xxEYt8,3v bFF )ǙrPNE8=O#V*Cc𹾾&l&cmCh<.P{ʦ&ۣY+Gxs~k5$> ӥPquŽўZt~Tl>Q.g> %k#ú:Kn'&{[yWQGqF}AЅ׮/}<;VYZa$wQg!$;_ $NKS}“_{MY|w7G!"\JtRy+贾d|o/;5jz_6fHwk<ѰJ#]kAȎ J =YNu%dxRwwbEQEQEQEQEQEQEQEQEQE'fLQZ(1F)hQ@X1KEQE-Q@ 1KE3h=iPb(((1GjZ(-ʹRPbR@ 1KE7`bڒyS0(-&)P+ ڎԴP11F)h&:LRmQ@Q@Š(((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((?l:ϊw "{{-3j3%{sj~2= 7 ~MڅKrHb|P3 r=Ҁ +Ş/$iu7=q2dԂxn⸷9$l]H #WI񯄴;\[ݚD8C3p&0U9^AnK vI+!I8>5(zqj03Y.X ,@85ߛ8>pq8=} \xmm常8` $Q@$v7zwp]ɝA GX;y_]覮O&4 SPtY.X),@84U=7Vuv K4,$g{@<+uqtiGw3; I@ORմn5MBp%8'ƫ%u6uBJrHRN2@ϸ J(9i[[m. _ZQ$hBTqN[ǐ2shh.}?~ι~~a@gshqh/"yD+U빾X2rXNT_y}ʏ{<ϴyicng8\LJ5ߴ^74,4"aXEL @43MoP"I.?: ;u/=+RDagDe ;G\ɗNWbH}^F̱8iJ 7ĺp^N]IX.@ IH;ûo\=֤[HtLAPT2crJwpr1Oxនgo|:֧ӼCa(;@`LnRF74I)?_h/;J2yJ$Q#ǔ"_d5߇vmz^qloËTW1mvВq`Wu?z?n>V7ۖۜ 8yg?g|1wP !4"ۉ*A}(89-ʟi\/>^o .1[#B pzBSg-> xGEpwvvKl%UKêG =KikRi:Lw -ܫ2$PU{#r*3<⇈t߉އ1-\\_D!yBFI!t>xbmգ kU9swrKk!uGgm6¬Ӑ qt(Rw׉?lg7Oy?71|=v~OmzM|)q^Y\%%H"=SJo{xއXZtupr2.u+V-M, uj> ťGt٧(J  23ˎA1jm[W|=_cmb!>d82X}B;n4>4.0H@çq^|ԓIo<ojiz\LDp|c˿ݍqszW? K ;q+( zno03haX r(뛉gG.;A'<* =vȼ}rY h F#o$ԄWAEg:95{/m['dɝ7)ꭂpgXw_2_zW.d v#ʺ(/|/.5&;B$xi9(q,Mw@x2C#|E;Cc#Z( M;ijb76sz>x&G {[L fb`mw;ӥvP?k>a-$!I!]KmAۜdgMWJ43S6Ka *y>LO,!#v*zu]mAuK2Ⱥ%v_,s$]clQ@޿ x]cCvp:BBqqxG·G t AیuPs ռG4I#C+ q1Yñ˰dPI `)N[X]bR$(8gU((((((((((((((((((((((((((+jZjv]e.cfE|b0}Ozx[ɴ|?{{e<!9$c[0M~sOVԴ|;.\ ̋2 8 0`ZJľ0ͪ,93J?3_:WX`M^V3(f3(wdJVmL[en`pUN20j=TG+ESxW[ܮ"]͵p۞0XV #ʀv;x;KH5or#E0Pz +ό fᛆ?/V\" cx;Xs^௄M.RymݖDe Y[#j)Pw\⯍5_ hZW|èǻ|e1ʖ\]vri6Rjumj-2fC2vp94Wųxvz˨DoxR2SL(oct)={m}XfШTNl'V94zo7rOupE]2 (# gXWf~ox]g֮1 toEЕ ʀI 2@==Z_7O𖩫]$.HTMIʕTڤ(+sZǏ-xwQ-Ʊ:QX`\|P6={fMW:oÆDtp1*HSʜ`C²訨( =gPuy4X}8|Ue8*j?| Z=ω_iWCF ڡY`@ǨQ\־)kJїЮ_-YUe2Ƞ78w0oǞ:Ȗu"Òe$/+ͷ> 4k|7ew~n ^Uƌ$ Tr}⇌/iq fZXBp 6 `N@";+g=B#yj.4P6Y 1F>Q7ׁ$IZ$4Jd;U*a@(cwW^>"|?>/7T[1!C.. e H棟~tyn1 fZ Bc+A+xpzdoYMpoylCT H&޿XC²訨(iEK[kÿH-縍Ih"``G%۸ExᯉݗWzzs쿀K3岗!G9<xVoiop {V$UH$aB 98Q@%Q@Q@Q@Q@Q@Q@Q@Q@Q@Q@Q@Q@Q@Q@Q@Q@Q@Q@Q@?J o^\߉<YеKEEr6*It#<???6޴>>hךV<%a]1Uc+'k:{=shX]BnFI#1u5P__iD*kb|9^Կ\Ys4=TGnxc9"5~ o- $B޸@V焾S^iRKFBa8"|U@8k㯆 jlI#TQ-$sJ_KaHrhc@cz\h>f4Jikv[)el9Aր<%AEn:GON(m{u ۋe:R"mUA\PH"IaY?TUVcvfml$NI'I'$?FK绚 n՘1U\ Aր9?5եO3>/&@ cWF zo sX<#jX2%@&_q\ ѷ#pElO7VEJ$E `+~ o- $B޸@P/%h9΁pn2ѰJ3n)?u}M״iǔH`3N$z'<[Ѵ㜦.瓅\*х kmR-?I\G1To"_T!x$ q%(QHzR w;sSnj5[76~TI7(v̈K1' qYHw߳9//V"᥸ B90x\rx GtFe\sb]Mm4}H@Oʿ|CI]g}gg{='!L Jo GÖkkc$:@oJ oUh=v~w,.-C3$r#he9D'k:{=shX]BnFI#1u5O7VEJ$E `(oC%Vհ7s Hk+*#*pFy?> skRLl三!P0WdEૻ']V6 J&FnzO_N+ x+t5u$KRI ry!@w߯hum`,^;2$,kpEbGJ WUOS7+Q'$j|+xZd.xA;\a;FpFqyK]V5`B>AEn:GON(o5 |Y٭kjeDF֑Ahaԫp1Ug{{oj &U)"8>C#>cagYgaiy rI8Q$5௄4WvrٶƽčXs ;[On}J=NBH,/HH b0WO:6keKfw,GqTѺ2p:rI&#@m-t;K@),YRĖ=I<:@QEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEV|W3:ŷ̑N2gڼU8M i^_2[y#bvrm@۲`(־2' |Gĉ5İS ;(QEQEQEQEQEV?|+xZd.xA;\a;FpFqlQ@=CD29Gbq^W?o l/7ݺEOnNաj~5o'uW>V7m3P@& ^hجl.Fc۵A¸`| ((?Q4=CAFH}g:ͧǟxj ͚EޞOo!g #pQEQEQEQEyfχ5"Oypw}{}h((((((((((((((((CO ޣoo%ݠb :1з<{%xt|/ 9mlsi(\ep@q}SJlu.S.cMJ0A  ^oWǺ?%/ Ho[.]櫪z]Ƨmgn(d5~>O|~w5!iZ5LŲF|'81@?W@- ?g'ټウ{WjUGںxHʙ# b̀,[qPnLuH x|A7Lm ԆpbU+rHA3> x={K%I~DÜb|]Dh4VRp]|ǏiCiXS(< eL>:S|`$VFKTl`ڥAhbp|)WIGR:h$X$2P3Md꽪8oߵ ԇkx@Rx{ExƍZ]"ϦƺwKVT-GO$ַ Ukwז3^I!YJ(46u뺶.-B4ymf;m8'^H=+{?[֟>lvٜ~f%;cv>_w[!niEK@qMv=WV~)ě%2VCҳr}đ('y;k m[Ur0bw̾ҿah$̱^HdTstB:hs 7zF荖ʬ2xe sפxDмOf4]r @UBu #<6u]Y?W|[ G<7c9 =GQ|iAu}coV_*n k+Ok"º,и۴ )rUB.r׮.m}BS:eN̒Rd(~&𖟨i5XaFaǜ18#(@^x?45ngTuxݘ .>|rB*U\O#sh SKY&+JpJq=auB"'_\ډSb^F;[hwch~O4 7o[Ŭ>=@Hl7e 9 ~Q=Zm4K=,-ͼQTXmx??6.ZX?6[*H`@xp$ Vuo?^B=ux.WԂcx>_s +u׃|[wSd[]l*ݎ8<-oxr{O.pE:lWw7P^[\5bn0F(((((((((((((((g%vc|3$FeOW1teZxXgQr,y>Ex[{Eo|[W_=0IFfgb?W<+=z2I26BYCpH x PkrRy??}/<~˝gWxSZG4aI mU.s$(=(on]6y<;Oz?1ϱm"vz(}a_ٿj闗fg4x'xB@g>~n׵tPW j?eûOoxnw jUiw6w X8 AW(nYWsݎ-%ռ'+ qO;NUr +:`(WQ@g| [}SO#e Z|~ΜWkNwdPHY(cuQW_[u]O4ϴ8zP)txL-uM@xR7d#`Hۦ:'>#΁uHsOa6C4nX Cc߉ м]eZöB]Bt#mRPW7Rk1.!83JA!s(’I'ݜ?CԆh1˴c4* r2'!p9 PQ^gz N^vdL';վ^0y(DZxDm F2Rsw`8s[K kx·Z3z궨ʥB#df9˞W?O5 `*|Iנ4Vk9Φ\-;p^InQuԦ|+j {e ċ!C: dSZI熿kFlRnqC7Q$PYEx?@ftyT}$Dw@<9?|a+SqKX4N|ѢG9+eN7cf=$5-r8$$JҢAǽu/aZmgK[h_r0N FAkW|A7|AɣH)J̜(6 "x/ƞ/8i1X38C e|/kY&vE8e$~gSPAEx$|N{Cw:n\"k ,j@ߌ2:O [VGiot_H kX󹊎zH:<9iQ$bvpn\i-,^Ȼ$m4!$ejs8ps+kO|$fSmrrEUbv9'O5 %;qj|b aݝo=%$B([SZh:JUxV}Z];el8I۴wc0(o&^XMB;fUDWGyy w?±k? 5)%p9TR*̌ǎA$>,+Rmt.{Hg.Juڬskn巸9 I]H#P?xn~m9PiY0 ap;Eyo -X驇x ʭ4I@%Xi <ۋx-.2Hyn |%ԯ>*F=Y.`I%Jo | ( IaY?TU߈׉-!} RP&ۏS? ~-xGNC6ik$fL2N^z(+6!J#I-Rh51yB8>o[/:;lٻk@<<RןeGÝFXj8$,71xF\ clߊ!Ľ,tk@L2v\1$ Huw҈+xR$;+c *9{P?h^e֟o4hԱ| zV?&o ]5O6i70#Ə2 }sZl7t.i쬡$d@q+Ywz5zv6S A,GUFV14PM7ÛW)!yYTȹoAd whn⸷LJTƌdE#ת_iv&A,71]3![ x= x^Oo/~4t8uɇcT>K.Ĝ#o?xwT?4k4c0]TBjJ o[?Lj4/QG-b۫(cF`9 d͏+RGYOi-鸹Y:R gEsTMGHu8VU$"r.[ne=/۫x-q$q+o5ciwfm͝l'#@#W39d_ ]!EraU1˷q'+Ľg^&xw>,KCRy=WI v`kC^Xj7h]B;ur vH$ 9>$7]Ŧjri~$O&+3Ư'*JrAT?m常H^I$2I39I8x+RnR{I]BEܪs=(U.\_xGﹷ-1whWB7`m?[xPk[;v0AUYn-rbCc_ =,[X5Tx׈ YBAp8w/|Qi?xV_6٘Bm~UQI<k^+o#[]F|-B8,{OY<C~WÛ]IkVNk@tA#|G^X/hr\Q@ɓJY'Miw qqytNm @ 9'0I@<6\K0DF dOkﯵO:V$ ^U!Ogb߁I=:C d3IO26ҤTѿ{b/BO3*z%QEQEQE ×zku{8:[PgWV|TfT)$r$` 1^hGBe}\NCK1`rzOIEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEylj=KId[q&9#l`>oop8*#?4W*~^^'(>@x(*?m{x(*?m{s;y_]覮d%pAI'}>UϰWPů:MoXC۲pp~^QEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEq# tؗu_6\ɒp7g |] )[u_׼c[07cvNIt->{s$04͒r }h"Y_Mn$WQc. m*:AOEBPS/dcommon/contbig.gif`GIF87a!!!111999BBBJJJRRRccckkksss{{{skk{{ZRRRJJƽ{sZRJRJB91)kcZB9)sskZRJ1޽ƽ{{ssskkkcƵZZRccZRRJJJB{BB9991ssckkZccR))!RRB!!JJ1))99!11ƌ)1R)k֔)s1RZJR{BJs9R1J!11J1J9k{csZk!1J!)cBR9J1B)91B!cRs{!)s!){1B!k!s!{ksksckckZc9B)1!)!)BJ9B1919έƌ!!)JJcZZ{!!!1RR{JJsBBkJJ{!!9BB{1!!J9)!!Z!!c1!!kR!!s9Z!BckJs)19!!c!!ZRZ,H rrxB(Kh" DժuICiи@S z$G3TTʖ&7!f b`D 0!A  k,>SO[!\ *_t  Exr%*_}!#U #4 & ֩3|b]L ]t b+Da&R_2lEٱZ`aC)/яmvUkS r(-iPE Vv_{z GLt\2s!F A#葡JY r|AA,hB}q|B`du }00(䡆<pb,G+oB C0p/x$…– ]7 @2HFc ) @AD \0 LHG',(A` `@SC)_" PH`}Y+_|1.K8pAKMA @?3҄$[JPA)+NH I ,@8G0/@R T,`pF8Ѓ)$^$ DDTDlA@ s;PKPKr>AOEBPS/dcommon/darbbook.cssPKPKr>A!OEBPS/dcommon/O_signature_clr.JPG"(JFIF``C    $.' ",#(7),01444'9=82<.342C  2!!22222222222222222222222222222222222222222222222222" }!1AQa"q2#BR$3br %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz w!1AQaq"2B #3Rbr $4%&'()*56789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz ?( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( (?O '~MQ$Vz;OlJi8L%\]UFjޙ%ԯS;rA]5ފ<׈]j7Ouyq$z'TQuw7Ŀ KX߁M2=S'TQt?.5w'97;~pq=" ~k?`'9q6 E|yayM^Om'fkC&<5x' ?A?Zx'jß={=SßM gVC.5+Hd֪xc^)Җufz{Cީ|D Vkznq|+Xa+{50rx{|OG.OϞ~f/ xxX[2H )c+#jpUOZYX\=SG ߨC|K@;_߆'e?LT?]:?>w ڔ`D^So~xo[Ӡ3i7B:Q8 Vc-ďoi:FM292~y_*_闱YN\Fr=xZ3鳎OwW_QEzW~c]REeaSM}}Hӏ4&.E]u=gMѠ+mF`rNn$w9gMa꺢nTuhf2Xv>އ a(Û6߭?<=>z'TQuw7Ŀ KX߁M2=S'TQt?.5Kko\.8S$TOX߀Gw?Zx汴X)C7~.i6(Щ=+4{mGӭ¸-]&'t_kV*I<1)4thtIsqpQJ+> \m^[aJ5)ny:4o&QEnyAEPEEss 72,PDۢ׃K W{Wjr+wگ iM/;pd?~&?@;7E4gv8 $l'z'TQuw7Ŀ Gֱ=ɿ&G?. iR(5W*$|?w᫼gkmIbHe/_t>tg%y.l}N5[]+Mk0ĠeHdPrsst'UiC,y8`V%9ZIia|ܪvi מYG,o}+kk{YbyIeb*sAtի82zWoEK5z*o-eo;n(P u-I)4Š(HQEQEQEQEhz(X/Đ?}Bk˩ ݏrk0]4>8XzV? }6$}d^F>nU K ?Bտk_9׾x~w'ߞ  uDŽtL ؈5c-E/"|_Oo.IH쐍=i*Iw5(ںw?t5s.)+tQ2dUt5Vĺ.jZ"@IRrZƅY4ߡ_;}ų(KyQf1Aǵt?sZg+?F5_oQR&Dg߿]6FuRD u>ڿxl7?IT8'shj^=.=J1rj1Wl$얲cPx;E,p$֟ˏkw qg"45(ǛkV/=+ũ)bYl~K#˝J_כ5&\F'I#8/|wʾ_Xj Q:os^T1.M_|TO.;?_  jF?g N 8nA2F%i =qW,G=5OU u8]Rq?wr'˻S+۾.ܼ 87Q^elo/T*?L|ۚ<%<,/v_OKs B5f/29n0=zqQq(ª=VX@*J(э(f5qJN_EVǞQEOuoѕOuoa5}gO?:߂8Wא|cڽ~]N&O( (<]>͠@VQ=^~U ̴m&\խ5i:}|}r~9՝f}_>'vVֲ$~^f30^in{\_.O F8to}?${φ|#x^#^n~w=~k~?'KRtO.㌡h![3Zu*ٷճ(ԟ]z_/W1(ԟ]v~g|Yq<ז0 ; b8֮s,w9\?uEyStKaª@\,)) (!EPEPEPEPEPzѧts{v>C/"N6`d*J2gGӧWqBq_1ZuΓ\X]r?=Ey88Mp&pKtO-"wR2 K^-Z< \c>V0^@O7x2WFjs<׻kZ(<Т(OFw/6$1[:ޯԯ#q~4|,LVPem=@=YLUxӃV}AUbcUB.Ds5*kٸAeG>PJxt͝ b88?*$~@ׯD VkraiJs}Q.20x&mXξ,Z]“A-J#`+-E/"<]\a'tZGy.(|lދ~gMK OZdxDŽU9T6ϯ^<Ϡt5CZ]].t۫S=s`ڳ%8iVK:nqe+#<.T6U>zWoy3^I {F?J~=G}k)K$$;$de8*G Uӟ4Ocºw}|]4=ݣ\x$ʠms?q^ipw\"ȿPs^Z Q_0GڼU.t}ROM[G#]8wٞ ӫ87}Cgw vHȩBM55vof =A_٭`Ygx[6 P,5}>蚊(0(+?>+?> k|TuXq6_ +szk :u_ Z߶Ak_U}Jc2u/1[_»ݸG41-bሬ۴}}Eȹפ_c?5gi @cL\L<68hF_Ih>X4K7UТ sMj =J7CKo>Օ5s:߀t ~ηaٿ?|gdL8+gG%o?x`دOqȱwc¨&TW_V_aI=dpG!wu۞սZ1yL50$(l3(:~'ַo A}a3N*[0ǭ HKQV}G@֜$ 9of$ArNqUOgË05#m?D)^_h//5_/<?4}Jį+GAOEBPS/dcommon/feedbck2.gif GIF89a1֔kRsBc)Jk9Z1R1,@IE1ӘÀ4Fq߰$aAXBqh@ܧI!$gp-fG*ed`/KRht4604buQAq:22ZJO,XfVjbH# & -, kJ>kpG4"$ r| >S4Ђ"S 1%R:ȝ 8;PKPz PKr>AOEBPS/dcommon/feedback.gif7GIF89a'%(hp|fdx?AN5:dfeDGHɾTdQc`g*6DC\?ؘ||{;=E6JUՄfeA= >@,4`H.|`a (Q 9:&[|ځ,4p Y&BDb,!2@, $wPA'ܠǃ@CO~/d.`I @8ArHx9H75j L 3B/` P#qD*s 3A:3,H70P,R@ p!(F oԥ D;"0 ,6QBRɄHhI@@VDLCk8@NBBL2&pClA?DAk%$`I2 #Q+l7 "=&dL&PRSLIP)PɼirqМ'N8[_}w;PK-PKr>AOEBPS/dcommon/booklist.gifGIF89a1޵֥΄kZ{Jk1Rs!BZ)B),@I9Z͓Ca % Dz8Ȁ0FZЌ0P !x8!eL8aWȠFD(~@p+rMS|ӛR$ v "Z:]ZJJEc{*=AP  BiA ']j4$*   & 9q sMiO?jQ = , YFg4.778c&$c%9;PKː5PKr>AOEBPS/dcommon/cpyr.htm1 Oracle Legal Notices

Oracle Legal Notices

Copyright Notice

Copyright © 1994-2012, Oracle and/or its affiliates. All rights reserved.

Trademark Notice

Oracle and Java are registered trademarks of Oracle and/or its affiliates. Other names may be trademarks of their respective owners.

Intel and Intel Xeon are trademarks or registered trademarks of Intel Corporation. All SPARC trademarks are used under license and are trademarks or registered trademarks of SPARC International, Inc. AMD, Opteron, the AMD logo, and the AMD Opteron logo are trademarks or registered trademarks of Advanced Micro Devices. UNIX is a registered trademark of The Open Group.

License Restrictions Warranty/Consequential Damages Disclaimer

This software and related documentation are provided under a license agreement containing restrictions on use and disclosure and are protected by intellectual property laws. Except as expressly permitted in your license agreement or allowed by law, you may not use, copy, reproduce, translate, broadcast, modify, license, transmit, distribute, exhibit, perform, publish, or display any part, in any form, or by any means. Reverse engineering, disassembly, or decompilation of this software, unless required by law for interoperability, is prohibited.

Warranty Disclaimer

The information contained herein is subject to change without notice and is not warranted to be error-free. If you find any errors, please report them to us in writing.

Restricted Rights Notice

If this is software or related documentation that is delivered to the U.S. Government or anyone licensing it on behalf of the U.S. Government, the following notice is applicable:

U.S. GOVERNMENT RIGHTS Programs, software, databases, and related documentation and technical data delivered to U.S. Government customers are "commercial computer software" or "commercial technical data" pursuant to the applicable Federal Acquisition Regulation and agency-specific supplemental regulations. As such, the use, duplication, disclosure, modification, and adaptation shall be subject to the restrictions and license terms set forth in the applicable Government contract, and, to the extent applicable by the terms of the Government contract, the additional rights set forth in FAR 52.227-19, Commercial Computer Software License (December 2007). Oracle America, Inc., 500 Oracle Parkway, Redwood City, CA 94065.

Hazardous Applications Notice

This software or hardware is developed for general use in a variety of information management applications. It is not developed or intended for use in any inherently dangerous applications, including applications that may create a risk of personal injury. If you use this software or hardware in dangerous applications, then you shall be responsible to take all appropriate fail-safe, backup, redundancy, and other measures to ensure its safe use. Oracle Corporation and its affiliates disclaim any liability for any damages caused by use of this software or hardware in dangerous applications.

Third-Party Content, Products, and Services Disclaimer

This software or hardware and documentation may provide access to or information on content, products, and services from third parties. Oracle Corporation and its affiliates are not responsible for and expressly disclaim all warranties of any kind with respect to third-party content, products, and services. Oracle Corporation and its affiliates will not be responsible for any loss, costs, or damages incurred due to your access to or use of third-party content, products, or services.

Alpha and Beta Draft Documentation Notice

If this document is in prerelease status:

This documentation is in prerelease status and is intended for demonstration and preliminary use only. It may not be specific to the hardware on which you are using the software. Oracle Corporation and its affiliates are not responsible for and expressly disclaim all warranties of any kind with respect to this documentation and will not be responsible for any loss, costs, or damages incurred due to the use of this documentation.

Oracle Logo

PKN61PKr>AOEBPS/dcommon/masterix.gif.GIF89a1ޜΌscJk1Rs!Bc1J),@IS@0"1 Ѿb$b08PbL,acr B@(fDn Jx11+\%1AOEBPS/dcommon/doccd.css,/* Minimal CSS for Oracle Database Documentation */ /* Standard Element Selectors */ h1, h2, h3, h4, h5, h6 { font-family: sans-serif; color: #309; background: white; } th { font-family: sans-serif; } a img { border-style: none; } div.header > p { display: none; } /* Class Selectors */ .ProductTitle { font-family: sans-serif; } .BookTitle { font-family: sans-serif; } .VersionNumber { font-family: sans-serif; } .PrintDate { font-family: sans-serif; font-size: small; } .PartNumber { font-family: sans-serif; font-size: small; } PKeӺ1,PKr>AOEBPS/dcommon/larrow.gif#GIF87a絵ƌֵƽ{{ss֜ƔZZ{{{{ZZssZZccJJJJRRBBJJJJ991111))!!{,@pH,Ȥrl:ШtpHc`  өb[.64AOEBPS/dcommon/indxicon.gifGIF87a!!!)))111999BBBJJJRRRZZZccckkksss{{{{s{sks,@pH,Ȥrl:Ш@Tx0CѠThDL q@(4L8C IrF   rM Dd aa CśfiiB PC9PA`S=gH B QDp1Ap)R"X3aƒC<₋0po 4P iU$4<… fe@kAC(oBݻL;PK#PKr>AOEBPS/dcommon/leftnav.gif"GIF89a1ֵƭޜ{scRkBc{,@H  &L*`t!4R! F K*Or IH0R+c JlMc!6,]",%%N w% O*%K" t`r6[ 51A0kgh$jvqj% * ?Q+ ! +{"@= y54T @K +}̶ P! t` FL<0DK1m2;PKS'"PKr>AOEBPS/dcommon/uarrow.gif/GIF89aJJss{{{ތJJﭭ{{BB{{ZZJJ11RR1199ΥJJssƵ!!ZZƽ޽Όcc))ZZֵƥ!% Imported from GIF image: arrtop.gif,JJss{{{ތJJﭭ{{BB{{ZZJJ11RR1199ΥJJssƵ!!ZZƽ޽Όcc))ZZֵƥ@pH,Ȥrl: "bJ56avEz5ᡠRYc`%))'5Vq &zq 25p]i +3-]s *,0}K )8N){N )2Kà);JéoFԴJܽҔėzI $7oFt2(0b  l< AOEBPS/dcommon/oracle.gifJGIF87aiyDT2F'G;Q_oKTC[ 3-Bq{ttsoGc4I)GvmLZ).1)!ꑈ53=Z]'yuLG*)g^!8C?-6(29K"Ĩ0Яl;U+K9^u2,@@ (\Ȱ Ë $P`lj 8x I$4H *(@͉0dа8tA  DсSP v"TUH PhP"Y1bxDǕ̧_=$I /& .)+ 60D)bB~=0#'& *D+l1MG CL1&+D`.1qVG ( "D2QL,p.;u. |r$p+5qBNl<TzB"\9e0u )@D,¹ 2@C~KU 'L6a9 /;<`P!D#Tal6XTYhn[p]݅ 7}B a&AƮe{EɲƮiEp#G}D#xTIzGFǂEc^q}) Y# (tۮNeGL*@/%UB:&k0{ &SdDnBQ^("@q #` @1B4i@ aNȅ@[\B >e007V[N(vpyFe Gb/&|aHZj@""~ӎ)t ? $ EQ.սJ$C,l]A `8A o B C?8cyA @Nz|`:`~7-G|yQ AqA6OzPbZ`>~#8=./edGA2nrBYR@ W h'j4p'!k 00 MT RNF6̙ m` (7%ꑀ;PKl-OJPKr>AOEBPS/dcommon/index.gifGIF89a1޵ΥΥ{sc{BZs,@IM" AD B0 3.R~[D"0, ]ШpRNC  /& H&[%7TM/`vS+-+ q D go@" 4o'Uxcxcc&k/ qp zUm(UHDDJBGMԃ;PK(PKr>AOEBPS/dcommon/bookbig.gif +GIF89a$!!!)))111999BBBJJJRRRZZZccckkksss{{{skkB991)))!!B11))1!JB9B9!!cZ9ƭƽssk{ZZRccZRRJJJBBB9c!!ν)1)k{s絽ƌkssֽZccJRRBJJ{9BB)11)99!!))11!!k!JZ!)RcJccBcs)1c)JZ!BR!)BZ)99J!Rk9!c11B)Z{)9Bkc1kB9BZ!Z{9Rs)Jkksk9kB1s1Jk9Rƥc{k9s)Z{1k91)s1Rk)Jc1J!))BZ!1k{csc{)19B!)Bcsc{ksc{kZs!RkJkJkքc{9Zks{ck9R)Bks9R9R1J!)Z1B!)c)9)99BR19kksBBJcc{ccBBZ))9kk!!199c11ZBB{9!!R!!Z!!c))!!kR!!s!!BcksRZ1c9B)R91c1)Z!R9B9k1)RcZ{)!1B9JB9B)!)J9B!& Imported from GIF image: bookbig.gif,$!!!)))111999BBBJJJRRRZZZccckkksss{{{skkB991)))!!B11))1!JB9B9!!cZ9ƭƽssk{ZZRccZRRJJJBBB9c!!ν)1)k{s絽ƌkssֽZccJRRBJJ{9BB)11)99!!))11!!k!JZ!)RcJccBcs)1c)JZ!BR!)BZ)99J!Rk9!c11B)Z{)9Bkc1kB9BZ!Z{9Rs)Jkksk9kB1s1Jk9Rƥc{k9s)Z{1k91)s1Rk)Jc1J!))BZ!1k{csc{)19B!)Bcsc{ksc{kZs!RkJkJkքc{9Zks{ck9R)Bks9R9R1J!)Z1B!)c)9)99BR19kksBBJcc{ccBBZ))9kk!!199c11ZBB{9!!R!!Z!!c))!!kR!!s!!BcksRZ1c9B)R91c1)Z!R9B9k1)RcZ{)!1B9JB9B)!)J9BH`\Ȑ:pظа"A6DBH,V@Dڹ'G"v Æ ܥ;n;!;>xAܽ[G.\rQC wr}BŊQ A9ᾑ#5Y0VȒj0l-GqF>ZpM rb ;=.ސW-WѻWo ha!}~ْ ; t 53 :\ 4PcD,0 4*_l0K3-`l.j!c Aa|2L4/1C`@@md;(H*80L0L(h*҇҆o#N84pC (xO@ A)J6rVlF r  fry†$r_pl5xhA+@A=F rGU a 1х4s&H Bdzt x#H%Rr (Ѐ7P`#Rщ'x" #0`@~i `HA'Tk?3!$`-A@1l"P LhʖRG&8A`0DcBH sq@AXB4@&yQhPAppxCQ(rBW00@DP1E?@lP1%T` 0 WB~nQ@;PKGC PKr>AOEBPS/dcommon/rarrow.gif/GIF87a絵ƌֵƽ{{ss֜ƔZZ{{{{ZZssZZccJJJJRRBBJJJJ991111))!!{,@pH,Ȥrl:ШLlԸ NCqWEd)#34vwwpN|0yhX!'+-[F 'n5 H $/14w3% C .90" qF 7&E "D mnB|,c96) I @0BW{ᢦdN p!5"D`0 T 0-]ʜ$;PKJV^PKr>AOEBPS/dcommon/mix.gifkGIF89aZZZBBBJJJkkk999sss!!!111cccֽ{{{RRR)))猌ƭ{s{sks!,@@pH,B$ 8 t:<8 *'ntPP DQ@rIBJLNPTVEMOQUWfj^!  hhG H  kCúk_a Ǥ^ h`B BeH mm  #F` I lpǎ,p B J\Y!T\(dǏ!Gdˆ R53ټ R;iʲ)G=@-xn.4Y BuU(*BL0PX v`[D! | >!/;xP` (Jj"M6 ;PK枰pkPKr>AOEBPS/dcommon/doccd_epub.jsM /* Copyright 2006, 2012, Oracle and/or its affiliates. All rights reserved. Author: Robert Crews Version: 2012.3.17 */ function addLoadEvent(func) { var oldOnload = window.onload; if (typeof(window.onload) != "function") window.onload = func; else window.onload = function() { oldOnload(); func(); } } function compactLists() { var lists = []; var ul = document.getElementsByTagName("ul"); for (var i = 0; i < ul.length; i++) lists.push(ul[i]); var ol = document.getElementsByTagName("ol"); for (var i = 0; i < ol.length; i++) lists.push(ol[i]); for (var i = 0; i < lists.length; i++) { var collapsible = true, c = []; var li = lists[i].getElementsByTagName("li"); for (var j = 0; j < li.length; j++) { var p = li[j].getElementsByTagName("p"); if (p.length > 1) collapsible = false; for (var k = 0; k < p.length; k++) { if ( getTextContent(p[k]).split(" ").length > 12 ) collapsible = false; c.push(p[k]); } } if (collapsible) { for (var j = 0; j < c.length; j++) { c[j].style.margin = "0"; } } } function getTextContent(e) { if (e.textContent) return e.textContent; if (e.innerText) return e.innerText; } } addLoadEvent(compactLists); function processIndex() { try { if (!/\/index.htm(?:|#.*)$/.test(window.location.href)) return false; } catch(e) {} var shortcut = []; lastPrefix = ""; var dd = document.getElementsByTagName("dd"); for (var i = 0; i < dd.length; i++) { if (dd[i].className != 'l1ix') continue; var prefix = getTextContent(dd[i]).substring(0, 2).toUpperCase(); if (!prefix.match(/^([A-Z0-9]{2})/)) continue; if (prefix == lastPrefix) continue; dd[i].id = prefix; var s = document.createElement("a"); s.href = "#" + prefix; s.appendChild(document.createTextNode(prefix)); shortcut.push(s); lastPrefix = prefix; } var h2 = document.getElementsByTagName("h2"); for (var i = 0; i < h2.length; i++) { var nav = document.createElement("div"); nav.style.position = "relative"; nav.style.top = "-1.5ex"; nav.style.left = "1.5em"; nav.style.width = "90%"; while (shortcut[0] && shortcut[0].toString().charAt(shortcut[0].toString().length - 2) == getTextContent(h2[i])) { nav.appendChild(shortcut.shift()); nav.appendChild(document.createTextNode("\u00A0 ")); } h2[i].parentNode.insertBefore(nav, h2[i].nextSibling); } function getTextContent(e) { if (e.textContent) return e.textContent; if (e.innerText) return e.innerText; } } addLoadEvent(processIndex); PKo"nR M PKr>AOEBPS/dcommon/toc.gifGIF89a1ΥΥ{c{Z{JkJk1Rk,@IK% 0| eJB,K-1i']Bt9dz0&pZ1o'q(؟dQ=3S SZC8db f&3v2@VPsuk2Gsiw`"IzE%< C !.hC IQ 3o?39T ҍ;PKv I PKr>AOEBPS/dcommon/topnav.gifGIF89a1ֽ筽ޭƔkZZk{Bc{,@ ) l)-'KR$&84 SI) XF P8te NRtHPp;Q%Q@'#rR4P fSQ o0MX[) v + `i9gda/&L9iAOEBPS/dcommon/prodicon.gifAGIF89a+m(O !{ n $&,fff,%+f333<=A 33f33cf)J\xzOZ%!PMY3f̺3f֚N33ff̙̙Zgk333fffff3ff__ff333fJ9)3!,@  C 9*4& #?/ $91  2& )300 >*1$#"%+ ( E' n7Ȇ(,҅(L@(Q$\x 8=6 'נ9tJ&"[Epljt p#ѣHb :f F`A =l|;&9lDP2ncH R `qtp!dȐYH›+?$4mBA9 i@@ ]@ꃤFxAD*^Ŵ#,(ε  $H}F.xf,BD Z;PK1FAPKr>AOEBPS/dcommon/bp_layout.css# @charset "utf-8"; /* bp_layout.css Copyright 2007, Oracle and/or its affiliates. All rights reserved. */ body { margin: 0ex; padding: 0ex; } h1 { display: none; } #FOOTER { border-top: #0d4988 solid 10px; background-color: inherit; color: #e4edf3; clear: both; } #FOOTER p { font-size: 80%; margin-top: 0em; margin-left: 1em; } #FOOTER a { background-color: inherit; color: gray; } #LEFTCOLUMN { float: left; width: 50%; } #RIGHTCOLUMN { float: right; width: 50%; clear: right; /* IE hack */ } #LEFTCOLUMN div.portlet { margin-left: 2ex; margin-right: 1ex; } #RIGHTCOLUMN div.portlet { margin-left: 1ex; margin-right: 2ex; } div.portlet { margin: 2ex 1ex; padding-left: 0.5em; padding-right: 0.5em; border: 1px #bcc solid; background-color: #f6f6ff; color: black; } div.portlet h2 { margin-top: 0.5ex; margin-bottom: 0ex; font-size: 110%; } div.portlet p { margin-top: 0ex; } div.portlet ul { list-style-type: none; padding-left: 0em; margin-left: 0em; /* IE Hack */ } div.portlet li { text-align: right; } div.portlet li cite { font-style: normal; float: left; } div.portlet li a { margin: 0px 0.2ex; padding: 0px 0.2ex; font-size: 95%; } #NAME { margin: 0em; padding: 0em; position: relative; top: 0.6ex; left: 10px; width: 80%; } #PRODUCT { font-size: 180%; } #LIBRARY { color: #0b3d73; background: inherit; font-size: 180%; font-family: serif; } #RELEASE { position: absolute; top: 28px; font-size: 80%; font-weight: bold; } #TOOLS { list-style-type: none; position: absolute; top: 1ex; right: 2em; margin: 0em; padding: 0em; background: inherit; color: black; } #TOOLS a { background: inherit; color: black; } #NAV { float: left; width: 96%; margin: 3ex 0em 0ex 0em; padding: 2ex 0em 0ex 4%; /* Avoiding horizontal scroll bars. */ list-style-type: none; background: transparent url(../gifs/nav_bg.gif) repeat-x bottom; } #NAV li { float: left; margin: 0ex 0.1em 0ex 0em; padding: 0ex 0em 0ex 0em; } #NAV li a { display: block; margin: 0em; padding: 3px 0.7em; border-top: 1px solid gray; border-right: 1px solid gray; border-bottom: none; border-left: 1px solid gray; background-color: #a6b3c8; color: #333; } #SUBNAV { float: right; width: 96%; margin: 0ex 0em 0ex 0em; padding: 0.1ex 4% 0.2ex 0em; /* Avoiding horizontal scroll bars. */ list-style-type: none; background-color: #0d4988; color: #e4edf3; } #SUBNAV li { float: right; } #SUBNAV li a { display: block; margin: 0em; padding: 0ex 0.5em; background-color: inherit; color: #e4edf3; } #SIMPLESEARCH { position: absolute; top: 5ex; right: 1em; } #CONTENT { clear: both; } #NAV a:hover, #PORTAL_1 #OVERVIEW a, #PORTAL_2 #OVERVIEW a, #PORTAL_3 #OVERVIEW a, #PORTAL_4 #ADMINISTRATION a, #PORTAL_5 #DEVELOPMENT a, #PORTAL_6 #DEVELOPMENT a, #PORTAL_7 #DEVELOPMENT a, #PORTAL_11 #INSTALLATION a, #PORTAL_15 #ADMINISTRATION a, #PORTAL_16 #ADMINISTRATION a { background-color: #0d4988; color: #e4edf3; padding-bottom: 4px; border-color: gray; } #SUBNAV a:hover, #PORTAL_2 #SEARCH a, #PORTAL_3 #BOOKS a, #PORTAL_6 #WAREHOUSING a, #PORTAL_7 #UNSTRUCTURED a, #PORTAL_15 #INTEGRATION a, #PORTAL_16 #GRID a { position: relative; top: 2px; background-color: white; color: #0a4e89; } PK3( # PKr>AOEBPS/dcommon/bookicon.gif:GIF87a!!!)))111999BBBJJJRRRZZZccckkksss{{{ޭ{{ZRRcZZRJJJBB)!!skRB9{sν{skskcZRJ1)!֭ƽ{ZZRccZJJBBB999111)JJ9BB1ZZB!!ﭵBJJ9BB!!))Jk{)1!)BRZJ{BsR!RRJsJ!J{s!JsBkks{RsB{J{c1RBs1ZB{9BJ9JZ!1BJRRs!9R!!9Z9!1)J19JJRk19R1Z)!1B9R1RB!)J!J1R)J119!9J91!9BkksBBJ119BBR!))9!!!JB1JJ!)19BJRZckތ1)1J9B,H*\hp >"p`ƒFF "a"E|ժOC&xCRz OBtX>XE*O>tdqAJ +,WxP!CYpQ HQzDHP)T njJM2ꔀJ2T0d#+I:<жk 'ꤱF AB @@nh Wz' H|-7f\A#yNR5 /PM09u UjćT|q~Yq@&0YZAPa`EzI /$AD Al!AAal 2H@$ PVAB&c*ؠ p @% p-`@b`uBa l&`3Ap8槖X~ vX$Eh`.JhAepA\"Bl, :Hk;PKx[?:PKr>AOEBPS/dcommon/conticon.gif^GIF87a!!!)))111999BBBJJJRRRZZZccckkksss{{{ZRR޽{{ssskkkcccZ991ccRZZBBJJZck)19ZcsBJZ19J!k{k)Z1RZs1!B)!J91{k{)J!B!B911)k{cs!1s!9)s!9!B!k)k1c!)Z!R{9BJcckZZcBBJ99B119{{!!)BBRBBZ!))999R99Z!!999c1!9!)19B1)!B9R,  oua\h2SYPa aowwxYi 9SwyyxxyYSd $'^qYȵYvh ч,/?g{н.J5fe{ڶyY#%/}‚e,Z|pAܠ `KYx,ĉ&@iX9|`p ]lR1khٜ'E 6ÅB0J;t X b RP(*MÄ!2cLhPC <0Ⴁ  $4!B 6lHC%<1e H 4p" L`P!/,m*1F`#D0D^!AO@..(``_؅QWK>_*OY0J@pw'tVh;PKp*c^PKr>AOEBPS/dcommon/blafdoc.cssL@charset "utf-8"; /* Copyright 2002, 2011, Oracle and/or its affiliates. All rights reserved. Author: Robert Crews Version: 2011.10.7 */ body { font-family: Tahoma, sans-serif; /* line-height: 125%; */ color: black; background-color: white; font-size: small; } * html body { /* http://www.info.com.ph/~etan/w3pantheon/style/modifiedsbmh.html */ font-size: x-small; /* for IE5.x/win */ f\ont-size: small; /* for other IE versions */ } h1 { font-size: 165%; font-weight: bold; border-bottom: 1px solid #ddd; width: 100%; } h2 { font-size: 152%; font-weight: bold; } h3 { font-size: 139%; font-weight: bold; } h4 { font-size: 126%; font-weight: bold; } h5 { font-size: 113%; font-weight: bold; display: inline; } h6 { font-size: 100%; font-weight: bold; font-style: italic; display: inline; } a:link { color: #039; background: inherit; } a:visited { color: #72007C; background: inherit; } a:hover { text-decoration: underline; } a img, img[usemap] { border-style: none; } code, pre, samp, tt { font-family: monospace; font-size: 110%; } caption { text-align: center; font-weight: bold; width: auto; } dt { font-weight: bold; } table { font-size: small; /* for ICEBrowser */ } td { vertical-align: top; } th { font-weight: bold; text-align: left; vertical-align: bottom; } ol ol { list-style-type: lower-alpha; } ol ol ol { list-style-type: lower-roman; } td p:first-child, td pre:first-child { margin-top: 0px; margin-bottom: 0px; } table.table-border { border-collapse: collapse; border-top: 1px solid #ccc; border-left: 1px solid #ccc; } table.table-border th { padding: 0.5ex 0.25em; color: black; background-color: #f7f7ea; border-right: 1px solid #ccc; border-bottom: 1px solid #ccc; } table.table-border td { padding: 0.5ex 0.25em; border-right: 1px solid #ccc; border-bottom: 1px solid #ccc; } span.gui-object, span.gui-object-action { font-weight: bold; } span.gui-object-title { } p.horizontal-rule { width: 100%; border: solid #cc9; border-width: 0px 0px 1px 0px; margin-bottom: 4ex; } div.zz-skip-header { display: none; } td.zz-nav-header-cell { text-align: left; font-size: 95%; width: 99%; color: black; background: inherit; font-weight: normal; vertical-align: top; margin-top: 0ex; padding-top: 0ex; } a.zz-nav-header-link { font-size: 95%; } td.zz-nav-button-cell { white-space: nowrap; text-align: center; width: 1%; vertical-align: top; padding-left: 4px; padding-right: 4px; margin-top: 0ex; padding-top: 0ex; } a.zz-nav-button-link { font-size: 90%; } div.zz-nav-footer-menu { width: 100%; text-align: center; margin-top: 2ex; margin-bottom: 4ex; } p.zz-legal-notice, a.zz-legal-notice-link { font-size: 85%; /* display: none; */ /* Uncomment to hide legal notice */ } /*************************************/ /* Begin DARB Formats */ /*************************************/ .bold, .codeinlinebold, .syntaxinlinebold, .term, .glossterm, .seghead, .glossaryterm, .keyword, .msg, .msgexplankw, .msgactionkw, .notep1, .xreftitlebold { font-weight: bold; } .italic, .codeinlineitalic, .syntaxinlineitalic, .variable, .xreftitleitalic { font-style: italic; } .bolditalic, .codeinlineboldital, .syntaxinlineboldital, .titleinfigure, .titleinexample, .titleintable, .titleinequation, .xreftitleboldital { font-weight: bold; font-style: italic; } .itemizedlisttitle, .orderedlisttitle, .segmentedlisttitle, .variablelisttitle { font-weight: bold; } .bridgehead, .titleinrefsubsect3 { font-weight: bold; } .titleinrefsubsect { font-size: 126%; font-weight: bold; } .titleinrefsubsect2 { font-size: 113%; font-weight: bold; } .subhead1 { display: block; font-size: 139%; font-weight: bold; } .subhead2 { display: block; font-weight: bold; } .subhead3 { font-weight: bold; } .underline { text-decoration: underline; } .superscript { vertical-align: super; } .subscript { vertical-align: sub; } .listofeft { border: none; } .betadraft, .alphabetanotice, .revenuerecognitionnotice { color: #e00; background: inherit; } .betadraftsubtitle { text-align: center; font-weight: bold; color: #e00; background: inherit; } .comment { color: #080; background: inherit; font-weight: bold; } .copyrightlogo { text-align: center; font-size: 85%; } .tocsubheader { list-style-type: none; } table.icons td { padding-left: 6px; padding-right: 6px; } .l1ix dd, dd dl.l2ix, dd dl.l3ix { margin-top: 0ex; margin-bottom: 0ex; } div.infoboxnote, div.infoboxnotewarn, div.infoboxnotealso { margin-top: 4ex; margin-right: 10%; margin-left: 10%; margin-bottom: 4ex; padding: 0.25em; border-top: 1pt solid gray; border-bottom: 1pt solid gray; } p.notep1 { margin-top: 0px; margin-bottom: 0px; } .tahiti-highlight-example { background: #ff9; text-decoration: inherit; } .tahiti-highlight-search { background: #9cf; text-decoration: inherit; } .tahiti-sidebar-heading { font-size: 110%; margin-bottom: 0px; padding-bottom: 0px; } /*************************************/ /* End DARB Formats */ /*************************************/ @media all { /* * * { line-height: 120%; } */ dd { margin-bottom: 2ex; } dl:first-child { margin-top: 2ex; } } @media print { body { font-size: 11pt; padding: 0px !important; } a:link, a:visited { color: black; background: inherit; } code, pre, samp, tt { font-size: 10pt; } #nav, #search_this_book, #comment_form, #comment_announcement, #flipNav, .noprint { display: none !important; } body#left-nav-present { overflow: visible !important; } } PKʍPKr>AOEBPS/dcommon/rightnav.gif&GIF89a1ֽ筽ޭƔkZZk{Bc{,@ ) l)- $CҠҀ ! D1 #:aS( c4B0 AC8 ְ9!%MLj Z * ctypJBa H t>#Sb(clhUAOEBPS/dcommon/oracle-small.JPG8JFIF``ExifII*C    $.' ",#(7),01444'9=82<.342C  2!!22222222222222222222222222222222222222222222222222'7" }!1AQa"q2#BR$3br %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz w!1AQaq"2B #3Rbr $4%&'()*56789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz ?( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( (QEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQE!KEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEQEzE7Ԃ̗4DztSԙ9ZQҀEPEPEPEPEPEPEPM=iԍP Gii c*yF 1׆@\&o!QY00_rlgV;)DGhCq7~..p&1c:u֫{fI>fJL$}BBP?JRWc<^j+χ5b[hֿ- 5_j?POkeQ^hֿ1L^ H ?Qi?z?+_xɔŪ\썽O]χ>)xxV/s)e6MI7*ߊޛv֗2J,;~E4yi3[nI`Ѱe9@zXF*W +]7QJ$$=&`a۾?]N T䏟'X)Ɣkf:j |>NBWzYx0t!* _KkoTZ?K Gc+UyڹgNuh^iSo5{\ܹ3Yos}.>if FqR5\/TӮ#]HS0DKu{($"2xִ{SBJ8=}Y=.|Tsц2UЫ%.InaegKo z ݎ3ֹxxwM&2S%';+I',kW&-"_¿_ Vq^ܫ6pfT2RV A^6RKetto^[{w\jPZ@ޢN4/XN#\42j\(z'j =~-I#:q[Eh|X:sp* bifp$TspZ-}NM*B-bb&*xUr#*$M|QWY ~p~- fTED6O.#$m+t$˙H"Gk=t9r娮Y? CzE[/*-{c*[w~o_?%ƔxZ:/5𨴟q}/]22p qD\H"K]ZMKR&\C3zĽ[PJm]AS)Ia^km M@dК)fT[ijW*hnu Ͳiw/bkExG£@f?Zu.s0(<`0ֹoxOaDx\zT-^ѧʧ_1+CP/p[w 9~U^[U<[tĽwPv[yzD1W='u$Oeak[^ |Gk2xv#2?¹TkSݕ| rݞ[Vi _Kz*{\c(Ck_܏|?u jVڔ6f t?3nmZ6f%QAjJf9Rq _j7Z-y.pG$Xb]0')[_k;$̭?&"0FOew7 z-cIX岛;$u=\an$ zmrILu uٞ% _1xcUW%dtÀx885Y^gn;}ӭ)場QEQ@Q@Q@Q@Q@Q@!4xPm3w*]b`F_931˜[ן+(> E ly;<;MF-qst+}DH @YKlLmؤciN<|]IU)Lw(8t9FS(=>og<\Z~u_+X1ylsj'eՃ*U3`C!N9Q_WܱhKc93^ua>H ƕGk=8~e#_?{ǀe-[2ٔ7;=&K挑5zsLdx(e8#{1wS+ΝVkXq9>&yஏh$zq^0~/j@:/«Vnce$$uoPp}MC{$-akH@ɫ1O !8R9s5ԦYmϧ'OUṡ5T,!Ԛ+s#1Veo=[)g>#< s)ƽُA^䠮ωFUj(ǩ|N3Jڷ睁ϱuږZYGOTsI<&drav?A^_f׻B$,O__ԿC`it{6>G׈C~&$y؎v1q9Sc1fH[ѽ>,gG'0'@Vw,BO [#>ﱺg5ΒFVD%Yr:O5 Tu+O멃]ی38Ze}R&ѝ_xzc1DXgس;<,_,{ƽY'AS#oF.M#~cBuEx7G+Y)(5q+GCV;qF+CLQ)qEC&6z𿊘z}?&w=+)??&\g{;V??׻xGœdٿ׼-Nc')3K]N)iLTӿCdb7Q^a N sd>Fz[0S^s'Zi 77D}kWus ab~~H(>.fif9,~|Jk;YN3H8Y(t6Q݉k͇_÷Z+2߄&[ +Tr^藺97~c܎=[f1RrBǓ^kEMhxYVm<[џ6| kqbѱ| YA{G8p?\UM7Z66 g1U1igU69 u5Pƪ:VVZC=[@ҹ¨$kSmɳО\vFz~i3^a Osŧυ9Q}_3 όO{/wgoet39 vO2ea;Ύ7$U#?k+Ek&dpzbӱ+TaB0gN{[N7Gי}U7&@?>Fz~E!a@s ?'67XxO*!?qi]֏TQN@tI+\^s8l0)2k!!iW8F$(yOּT.k,/#1:}8uT˾+5=O/`IW G֯b.-<= HOm;~so~hW5+kS8s.zwE| ?4ӿw/K N 9?j(#0UT` Wzw}:_*9m>󑓀F?ELzv=8q:=WgJ`nDr Zе<ֹ](Q@Q@Q@Q@Q@Q@Q@Q@ 'IdC0EYJVcMty_~u+Sw-aO n<[YJgL#6i g5ЖDZ14cʝ!!\/M}/_AYR__>oC? _?7_G#RERW쏞KB}JxGSkǕA pƱơP m]hwB7U$Zq M95"3q1ioATߚ{g.t uu2k=;h#YB= fgS :TdLԃ!44mFK{Hrd^7oz|BVr<{)6AXգV»|>*/hS܏z͆OM=Εq (s|s׊LKQI :9NJ)P+!ʣoAF>+=@I}"x/}۠1aנc¹4emC:>p_xWKX` >R3_S½èųp3޺u3N e یbmͺ<_ mnݮ1Op?Gm)Qb%N585'%Ahs\6yw!"&Ɨ._wk)}GP;Z!#\"< *oƾ\)}N>"լ/~]Lg}pBG X?<zZ#x69S=6) jzx=y9O&>+e!!? ?s~k5Gʏ)?*ce7Ox~k5􇔾Q/e7/Ԑ#3OgNC0] ;_FiRl>Q.g>!%k#ú:Kn'&}?U@\pџPtp)v<{_i}Oվֲ3XIYIx~b<D?(=_JXH=bbi=Oh?_ C_O)}oW쏜? %Ƶ;-RYFi`wۭ{ϖZMtQ$"c_+ԃx1*0b;ԕ݋ESQEQEQEQEQEQEQEQEQEQZ(1F)h1K@XLRE&9P (bf{RӨ&)PEPEPbԴPGKZ(iإbn(:A%S0(-&)P+ ڎԴP11F)h&:LRmQ@Q@Š(((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((PKje88PKr>AOEBPS/dcommon/help.gif!GIF89a1εֵ֜֜{kZsBc{,@ )sƠTQ$8(4ʔ%ŌCK$A HP`$h8ŒSd+ɡ\ H@%' 6M HO3SJM /:Zi[7 \( R9r ERI%  N=aq   qƦs *q-n/Sqj D XZ;PKއ{&!PKr>A OEBPS/toc.htm^8 Table of Contents

Contents

List of Figures

List of Tables

Title and Copyright Information

Preface

What's New in Heterogeneous Connectivity User's Guide?

1 Introduction

2 The Role of the Heterogeneous Services Component

3 Features of Oracle Database Gateways

4 Using Heterogeneous Services Agents

5 Performance Recommendations

Index

PK؏Cc8^8PKr>AOEBPS/majfeat.htm Features of Oracle Database Gateways

3 Features of Oracle Database Gateways

This chapter describes the major features provided by Oracle Database gateways. Descriptions of these features are in the following topics:

  • SQL and PL/SQL Support

  • Heterogeneous Replication

  • Passthrough SQL

  • Result Set Support

  • Data Dictionary Translations

  • Date-Time Data Types

  • Two-Phase Commit Protocol

  • Piecewise LONG Data Type

  • SQL*Plus DESCRIBE Command

  • Constraints on SQL in a Distributed Environment

  • Oracle's Optimizer and Heterogeneous Services


    Note:

    These features may not be available in all Heterogeneous Services gateways. Not only must there be generic support for these features, which Heterogeneous Services provides, but there must also be support added to the driver for them. Consult the appropriate gateway documentation to determine if a particular feature is supported for your gateway.

3.1 SQL and PL/SQL Support

SQL statements are translated and data types are mapped according to capabilities. PL/SQL calls are mapped to non-Oracle system stored procedures. With SQL statements, if functionality is missing at the remote system, then either a simpler query is issued or the statement is broken up into multiple queries. Then, the desired results are obtained by postprocessing in the Oracle database.

Even though Heterogeneous Services can, for the most part, incorporate non-Oracle systems into Oracle distributed sessions, there are several limitations to this. Some of the generic limitations are:

  • There is no support for CONNECT BY clauses in SQL statements.

  • ROWID support is limited; consult individual gateway documentation for more details. The Oracle Universal ROWID data type is not supported in any gateway that uses Heterogeneous Services.

  • Large objects (LOBs), abstract data types (ADTs), and reference data types (REFs) are not supported.

  • Remote packages are not supported.

  • Remote stored procedures can have out arguments of type REF CURSOR but not in or in-out objects.

  • Oracle Heterogeneous Services agents do not support shared database links.


    Note:

    In addition to these generic limitations, each gateway can have additional limitations. See the gateway documentation for individual gateways for a complete list of limitations of the product.

3.2 Heterogeneous Replication

Data can be replicated between a non-Oracle system and Oracle Database using materialized views.


Note:

There is another means of replicating information between Oracle and non-Oracle databases called Oracle Streams.

For information about using Oracle Streams, see Oracle Streams Concepts and Administration.


Materialized views instantiate data captured from tables at the non-Oracle master site at a particular time. This instant is defined by a refresh operation, which copies this data to Oracle Database and synchronizes the copy on the Oracle system with the master copy on the non-Oracle system. The materialized data is then available as a view on Oracle Database.

Replication facilities provide mechanisms to schedule refreshes and to collect materialized views into replication groups to facilitate their administration. Refresh groups permit refreshing multiple materialized views as if they were a single object.

Heterogeneous replication support is necessarily limited to a subset of the full Oracle-to-Oracle replication functionality:

  • Only the non-Oracle system can be the primary site. This is because materialized views can be created only on Oracle Database.

  • Materialized views must use a complete refresh. This is because fast refresh would require Oracle-specific functionality in the non-Oracle system.

  • Not all types of materialized views can be created to reference tables on a non-Oracle system. Primary key and subquery materialized views are supported, but ROWID and OBJECT ID materialized views are not supported. This is because there is no SQL standard for the format and contents of ROWID, and non-Oracle systems do not implement Oracle objects.

Other restrictions apply to any access to non-Oracle data through Oracle's Heterogeneous Services facilities. The most important of these are:

  • Non-Oracle data types in table columns mapped to a fixed view must be compatible with (that is, have a mapping to or from) Oracle data types. This is usually true for data types defined by ANSI SQL standards.

  • A subquery materialized view may not be able to use language features restricted by individual non-Oracle systems. In many cases, Heterogeneous Services supports such language features by processing queries within Oracle Database. Occasionally the non-Oracle systems impose limitations that cannot be detected until Heterogeneous Services attempts to execute the query.

The following examples illustrate basic setup and use of three materialized views to replicate data from a non-Oracle system to an Oracle data store.


Note:

For the following examples, remote_db refers to the non-Oracle system that you are accessing from Oracle Database.

Modify these examples for your environment. Do not try to execute them as they are written.


Example 1: Create Materialized Views for Heterogeneous Replication

This example creates three materialized views that are then used in subsequent examples.

  1. Create a primary key materialized view of table customer@remote_db.

    CREATE MATERIALIZED VIEW pk_mv REFRESH COMPLETE AS
      SELECT * FROM customer@remote_db WHERE "zip" = 94555;
  1. Create a subquery materialized view of tables orders@remote_db and customer@remote_db.

    CREATE MATERIALIZED VIEW sq_mv REFRESH COMPLETE AS
      SELECT * FROM orders@remote_db o WHERE EXISTS
        (SELECT c."c_id" FROM customer@remote_db c
           WHERE c."zip" = 94555 and c."c_id"  = o."c_id" );
  1. Create a complex materialized view of data from multiple tables on remote_db.

    CREATE MATERIALIZED VIEW cx_mv
      REFRESH COMPLETE AS
      SELECT  c."c_id", o."o_id"
        FROM customer@remote_db c,
             orders@remote_db o,
             order_line@remote_db ol
        WHERE c."c_id" = o."c_id"
        AND o."o_id" = ol."o_id";

Example 2: Set Up a Refresh Group for Heterogeneous Replication

BEGIN
  dbms_refresh.make('refgroup1',
   'pk_mv, sq_mv, cx_mv',
   NULL, NULL);
 END;
 /

Example 3: Force Refresh of All Three Materialized Views

BEGIN
   dbms_refresh.refresh('refgroup1');
END;
 /

See Also:

Oracle Database Advanced Replication for a complete description of materialized views and replication facilities

3.3 Passthrough SQL

The passthrough SQL feature enables you to send a statement directly to a non-Oracle system without first being interpreted by Oracle Database. This feature can be useful if the non-Oracle system allows for operations in statements for which there is no equivalent in Oracle.

This section contains the following topics:

  • Using the DBMS_HS_PASSTHROUGH Package

  • Considering the Implications of Using Passthrough SQL

  • Executing Passthrough SQL Statements

3.3.1 Using the DBMS_HS_PASSTHROUGH Package

You can execute passthrough SQL statements directly on the non-Oracle system using the PL/SQL package DBMS_HS_PASSTHROUGH. Any statement executed with this package is executed in the same transaction as standard SQL statements.

The DBMS_HS_PASSTHROUGH package is a virtual package. It conceptually resides on the non-Oracle system. In reality, however, calls to this package are intercepted by Heterogeneous Services and are mapped to one or more Heterogeneous Services calls. The driver then maps these Heterogeneous Services calls to the API of the non-Oracle system. The client application invokes the procedures in the package through a database link in the same way as it would invoke a non-Oracle system stored procedure. The special processing done by Heterogeneous Services is transparent to the user.


See Also:

Oracle Database PL/SQL Packages and Types Reference for more information about this package

3.3.2 Considering the Implications of Using Passthrough SQL

When you execute a passthrough SQL statement that implicitly commits or rolls back a transaction in a non-Oracle system, the transaction is affected. For example, some systems implicitly commit the transaction containing a data definition language (DDL) statement. Because Oracle Database is bypassed, Oracle Database is unaware that a transaction was committed in the non-Oracle system. Consequently, the data at the non-Oracle system can be committed, while the transaction in Oracle Database is not.

If the transaction in Oracle Database is rolled back, data inconsistencies between Oracle Database and the non-Oracle system can occur. This situation results in global data inconsistency.

Note that if the application executes a typical COMMIT statement, Oracle Database can coordinate the distributed transaction with the non-Oracle system. The statement executed with the passthrough facility is part of the distributed transaction.

3.3.3 Executing Passthrough SQL Statements

The following table shows the functions and procedures provided by the DBMS_HS_PASSTHROUGH package that enable you to execute passthrough SQL statements.

Procedure/FunctionDescription
OPEN_CURSOROpens a cursor.
CLOSE_CURSORCloses a cursor.
PARSEParses the statement.
BIND_VARIABLEBinds IN variables.
BIND_OUT_VARIABLEBinds OUT variables.
BIND_INOUT_VARIABLEBinds IN OUT variables.
EXECUTE_NON_QUERYExecutes a nonquery statement.
EXECUTE_IMMEDIATEExecutes a nonquery statement without bind variables.
FETCH_ROWFetches rows from query.
GET_VALUERetrieves column value from SELECT statement or retrieves OUT bind parameters.

3.3.3.1 Executing Nonqueries

Nonqueries include the following statements and types of statements:

  • INSERT

  • UPDATE

  • DELETE

  • DDL

To execute nonquery statements, use the EXECUTE_IMMEDIATE function. For example, to execute a DDL statement on a non-Oracle system that you can access using the database link salesdb, enter the following:

DECLARE
  num_rows INTEGER;

BEGIN
  num_rows := DBMS_HS_PASSTHROUGH.EXECUTE_IMMEDIATE@salesdb
            ('CREATE TABLE dept1 (n SMALLINT, loc CHARACTER(10))');
END;

The variable num_rows is assigned the number of rows affected by the statements that were executed. For DDL statements, zero is returned. Note that you cannot execute a query with EXECUTE_IMMEDIATE function and you cannot use bind variables.

3.3.3.1.1 Using Bind Variables: Overview

Bind variables let you use the same SQL statement multiple times with different values, reducing the number of times a SQL statement needs to be parsed. For example, when you insert four rows in a table, you can parse the SQL statement once, and bind and execute the SQL statement for each row. One SQL statement can have zero or more bind variables.

To execute passthrough SQL statements with bind variables, you must:

  1. Open a cursor.

  2. Parse the SQL statement on the non-Oracle system.

  3. Bind the variables.

  4. Execute the SQL statement on the non-Oracle system.

  5. Close the cursor.

Figure 3-1 shows the flow diagram for executing nonqueries with bind variables.

Figure 3-1 Flow Diagram for Nonquery Passthrough SQL

Description of Figure 3-1 follows
Description of "Figure 3-1 Flow Diagram for Nonquery Passthrough SQL"

3.3.3.1.2 Using IN Bind Variables

The syntax of the non-Oracle system determines how a statement specifies a bind variable. For example, on an Oracle system you define bind variables with a preceding colon. For example:

...
UPDATE emp
SET sal=sal*1.1
WHERE ename=:ename;
...

In this statement, ename is the bind variable. On non-Oracle systems, you may need to specify bind variables with a question mark. For example:

...
UPDATE emp
SET sal=sal*1.1
WHERE ename= ?;
...

In the bind variable step, you must positionally associate host program variables (in this case, PL/SQL) with each of these bind variables. For example, to execute the preceding statement, use the following PL/SQL program:

DECLARE
  c INTEGER;
  nr INTEGER;
BEGIN
  c := DBMS_HS_PASSTHROUGH.OPEN_CURSOR@salesdb;
  DBMS_HS_PASSTHROUGH.PARSE@salesdb(c,
        'UPDATE emp SET SAL=SAL*1.1 WHERE ename=?');
  DBMS_HS_PASSTHROUGH.BIND_VARIABLE@salesdb(c,1,'JONES');
  nr:=DBMS_HS_PASSTHROUGH.EXECUTE_NON_QUERY@salesdb(c);
  DBMS_OUTPUT.PUT_LINE(nr||' rows updated');
  DBMS_HS_PASSTHROUGH.CLOSE_CURSOR@salesdb(c);
END;
3.3.3.1.3 Using OUT Bind Variables

The non-Oracle system can support OUT bind variables. With OUT bind variables, the value of the bind variable is not known until after the execution of the SQL statement.

Although OUT bind variables are populated after executing the SQL statement, the non-Oracle system must know that the particular bind variable is an OUT bind variable before the SQL statement is executed. You must use the BIND_OUT_VARIABLE procedure to specify that the bind variable is an OUT bind variable.

After executing the SQL statement, you can retrieve the value of the OUT bind variable using the GET_VALUE procedure.

3.3.3.1.4 Using IN OUT Bind Variables

A bind variable can be both an IN and an OUT variable. This means that the value of the bind variable must be known before executing the SQL statement, but you can change the value after the SQL statement is executed.

For IN OUT bind variables, you must use the BIND_INOUT_VARIABLE procedure to provide a value before executing the SQL statement. After executing the SQL statement, you must use the GET_VALUE procedure to retrieve the new value of the bind variable.

3.3.3.2 Executing Queries

The difference between queries and nonqueries is that queries retrieve a result set from a SELECT statement. The result set is retrieved by using a cursor.

Figure 3-2 illustrates the steps in a passthrough SQL query. After the system parses the SELECT statement, each row of the result set can be retrieved with the FETCH_ROW procedure. After the row is retrieved, use the GET_VALUE procedure to retrieve the selected list of items into program variables. After all rows are retrieved, you can close the cursor.

Figure 3-2 Passthrough SQL for Queries

Description of Figure 3-2 follows
Description of "Figure 3-2 Passthrough SQL for Queries"

You do not have to retrieve all the rows. You can close the cursor at any time after opening the cursor.


Note:

Although you are retrieving one row at a time, Heterogeneous Services optimizes the round-trips between Oracle Database and the non-Oracle system by buffering multiple rows and fetching from the non-Oracle data system in one round-trip.

The following example executes a query:

DECLARE
   val  VARCHAR2(100);
   c    INTEGER;
   nr   INTEGER;
BEGIN
  c := DBMS_HS_PASSTHROUGH.OPEN_CURSOR@salesdb; 
  DBMS_HS_PASSTHROUGH.PARSE@salesdb(c, 
    'select ENAME
     from   EMP
     where  DEPTNO=10');
  LOOP
    nr := DBMS_HS_PASSTHROUGH.FETCH_ROW@salesdb(c);
    EXIT WHEN nr = 0;
    DBMS_HS_PASSTHROUGH.GET_VALUE@salesdb(c, 1, val);
    DBMS_OUTPUT.PUT_LINE(val);
  END LOOP;  
  DBMS_HS_PASSTHROUGH.CLOSE_CURSOR@salesdb(c); 
END;

After the SELECT statement has been parsed, the rows are fetched and printed in a loop until the FETCH_ROW function returns the value 0.

3.4 Result Set Support

Various relational databases enable stored procedures to return result sets (one or more sets of rows).

Traditionally, database stored procedures worked exactly like procedures in any high-level programming language. They had a fixed number of arguments which could be of types IN, OUT, or IN OUT. If a procedure had n arguments, it could return at most n values as results. However, suppose that you wanted a stored procedure to execute a query such as SELECT * FROM emp and return the results. The emp table might have a fixed number of columns, but there is no way of telling, at procedure creation time, the number of rows it has. Because of this, no traditional stored procedure could be created that returned the results of this type of query. As a result, several relational database vendors added the ability to return results sets from stored procedures, but each relational database returns result sets from stored procedures differently.

Oracle has a data type called a REF CURSOR. Like every other Oracle data type, a stored procedure can take this data type as an IN or OUT argument. With Oracle Database, a stored procedure must have an output argument of type REF CURSOR. It then opens a cursor for a SQL statement and places a handle to that cursor in that output parameter. The caller can then retrieve from the REF CURSOR the same way as from any other cursor.

Oracle Database can do a lot more than return result sets. The REF CURSOR data type can be passed as an input argument to PL/SQL routines to be passed back and forth between client programs and PL/SQL routines or as an input argument between several PL/SQL routines.

This section contains the following topics:

  • Result Set Support for Non-Oracle Systems

  • Heterogeneous Services Support for Result Sets

3.4.1 Result Set Support for Non-Oracle Systems

Several non-Oracle systems allow stored procedures to return result sets, but they do so in different ways. Result set support for non-Oracle databases is typically based on one of the following two models.

  • Model 1: Result Set Support

    When creating a stored procedure, you can explicitly specify the maximum number of result sets that can be returned by that stored procedure. While executing, the stored procedure can open anywhere from zero up to its specified maximum number of result sets. After the execution of the stored procedure, a client program gets handles to these result sets by using either an embedded SQL directive or by calling a client library function. After that, the client program can retrieve from the result set in the same way as from a typical cursor.

  • Model 2: Result Set Support

    In this model, there is no specified limit to the number of result sets that can be returned by a stored procedure. Both Model 1 and Oracle Database have a limit. For Oracle Database, the number of result sets returned by a stored procedure can be at most the number of REF CURSOR OUT arguments. For Model 1, the upper limit is specified using a directive in the stored procedure language. Another way that Model 2 differs from Oracle Database and Model 1 is that they do not return a handle to the result sets. Instead, they place the entire result set on the wire when returning from a stored procedure. For Oracle Database, the handle is the REF CURSOR OUT argument. For Model 1, it is obtained separately after the execution of the stored procedure. For both Oracle Database and Model 1, after the handle is obtained, data from the result set is obtained by doing a fetch on the handle; there are several cursors open and the fetch can be in any order. In the case of Model 2, however, all the data is already on the wire, with the result sets coming in the order determined by the stored procedure and the output arguments of the procedures coming at the end. The entire first result set must be retrieved, then the entire second result set, until all of the results are retrieved. Finally, the stored procedure OUT arguments are retrieved.

3.4.2 Heterogeneous Services Support for Result Sets

Result set support exists among non-Oracle databases in different forms. All of these must be mapped to the Oracle REF CURSOR model. Due to the differences in behavior among the non-Oracle systems, Heterogeneous Services result set support acts in one of two different ways depending on the non-Oracle system to which it is connected.

Note the following about Heterogeneous Services result set support:

  • Result set support is part of the Heterogeneous Services generic code, but for the feature to work in a gateway, the driver has to implement it. Not all drivers have implemented result set support and you must verify that your gateway is supported.

  • Heterogeneous Services supports REF CURSOR OUT arguments from stored procedures. IN and IN OUT arguments are not supported.

  • The REF CURSOR OUT arguments are all anonymous reference cursors. REF CURSORs that are returned by Heterogeneous Services do not have types.

3.4.2.1 Results Sets: Cursor Mode

Each result set returned by a non-Oracle system stored procedure is mapped by an Oracle driver to an OUT argument of type REF CURSOR. The client program detects a stored procedure with several OUT arguments of type REF CURSOR. After executing the stored procedure, the client program can fetch from the REF CURSOR the same way as it would from a REF CURSOR returned by an Oracle stored procedure. When connecting to the gateway as described in Section 3.4.1.1, Heterogeneous Services will be in cursor mode.

3.4.2.2 Result Sets: Sequential Mode

There is a maximum number of result sets that a particular stored procedure can return. The number of result sets returned is at most the number of REF CURSOR OUT arguments for the stored procedure. It can return fewer result sets, but it can never return more.

For the system described in Section 3.4.1.2, there is no maximum number of result sets that can be returned. In the case of Model 1 (in Section 3.4.1.1), the maximum number of result sets that a procedure can return is known, and that the driver can return to Heterogeneous Services, is specified in the stored procedure by the number of REF CURSOR OUT arguments. If, when the stored procedure is executed, fewer result sets than the maximum are returned, then the other REF CURSOR OUT arguments are set to NULL.

Another problem for Model 2 database servers is that result sets must be retrieved in the order in which they were placed on the wire by the database. This prevents Heterogeneous Services from running in cursor mode when connecting to these databases. To access result sets returned by these stored procedures, Heterogeneous Services must be in sequential mode.

In sequential mode, the procedure description returned by the driver contains the following:

  • All the input arguments of the remote stored procedure

  • None of the output arguments

  • One OUT argument of type REF CURSOR (corresponding to the first result set returned by the stored procedure)

The client fetches from this REF CURSOR and then calls the virtual package function DBMS_HS_RESULT_SET.GET_NEXT_RESULT_SET to fetch the REF CURSOR corresponding to the next result set. This function call repeats until all result sets are retrieved. The last result set returned will be the OUT arguments of the remote stored procedure.

The primary limitations of sequential mode are:

  • Result sets returned by a remote stored procedure must be retrieved in the order in which they were placed on the wire.

  • When a stored procedure is executed, all result sets returned by a previously executed stored procedure are closed (regardless of whether or not the data was retrieved).


    See Also:

    Your gateway-specific manual for more information about how result sets are supported through the gateway

3.5 Data Dictionary Translations

Most database systems have some form of data dictionary. A data dictionary is a collection of information about the database objects that were created by various users of the system. For a relational database, a data dictionary is a set of tables and views that contain information about the data in the database. This information includes information about the users who are using the system and about the objects that they created (such as tables, views, and triggers). Almost all data dictionaries (regardless of the database system) contain the same information, but each database system organizes the information differently.

For example, the ALL_CATALOG Oracle data dictionary view gives a list of tables, views, and sequences in the database. It has three columns: the first is called OWNER, and it is the name of the owner of the object; the second is called TABLE_NAME, and it is the name of the object; and the third is called TABLE_TYPE, and it is the data type. This field has value TABLE, VIEW, SEQUENCE and so forth depending on the object type. However, in Sybase, the same information is stored in two tables called sysusers and sysobjects whose column names are different from those of the Oracle ALL_CATALOG table. Additionally, in Oracle Database, the table type is a string with a value such as TABLE or VIEW. With Sybase, it is a letter, for example, U means user table; S means system table; V means view, and so forth.

If the client program requires information from the table ALL_CATALOG on a Sybase system, it sends a query referencing ALL_CATALOG@database_link to a gateway. Heterogeneous Services translates this query to an appropriate query on systables and then sends the translated query to the Sybase system, for example:

SELECT SU."name" OWNER, SO."name" TABLE_NAME,
   DECODE(SO."type", 'U ','TABLE', 'S ', 'TABLE', 'V ', 'VIEW')
TABLE_TYPE
FROM "dbo"."sysusers"@remote_db  SU, "dbo"."sysobjects"@remote_db SO
WHERE SU."uid" = SO."uid" AND
   (SO."type" = 'V' OR SO."type" = 'S' OR SO."type" = 'U');

To relay the translation of a query on an Oracle data dictionary table to the equivalent one on the non-Oracle system data dictionary table, Heterogeneous Services needs data dictionary translations for that non-Oracle system. A data dictionary translation is a view definition (essentially a SELECT statement) of one or more non-Oracle system data dictionary tables that look like the Oracle data dictionary table, with the same column names and the same formatting. Most data dictionary translations are not as simple as the preceding example. Often, the information is scattered over many tables, and the data dictionary translation is a complex join of those tables.

In some cases, an Oracle data dictionary table does not have a translation because the information does not exist on the non-Oracle system. In such cases, the gateway must not upload a translation, or the gateway might implement an alternative approach called mimicking. If the gateway mimics a data dictionary table, it informs Heterogeneous Services, and Heterogeneous Services will get the description of the data dictionary table by querying the local database. When asked to retrieve data, it will report that no rows were selected.

3.6 Date-Time Data Types

Oracle Database has five date-time data types:

  • TIMESTAMP

  • TIMESTAMP WITH TIME ZONE

  • TIMESTAMP WITH LOCAL TIME ZONE

  • INTERVAL YEAR TO MONTH

  • INTERVAL DAY TO SECOND

Heterogeneous Services generic code supports Oracle date-time data types in SQL and stored procedures. Heterogeneous Services does not support these data types in data dictionary translations or queries involving data dictionary translations.

Even though Heterogeneous Services generic code supports date-time data types, support for a particular gateway depends on whether or not the driver for that non-Oracle system implemented date-time support. Support, even when the driver implements it, may be partial because of the limitations of the non-Oracle system. For more information, see your gateway-specific documentation.

You must set the timestamp formats of the non-Oracle system in the gateway initialization file. The parameters to set are HS_NLS_TIMESTAMP_FORMAT and HS_NLS_TIMESTAMP_TZ_FORMAT. You should also set the local time zone for the non-Oracle system in the initialization file by setting HS_TIME_ZONE.


See Also:

Oracle Database SQL Language Reference for information about datetime data types

3.7 Two-Phase Commit Protocol

Heterogeneous Services provides the infrastructure to implement the two-phase commit protocol. The extent to which this is supported depends on the gateway and the remote system. For more information, see your gateway-specific documentation.


See Also:

Oracle Database Administrator's Guide for more information about the two-phase commit protocol

3.8 Piecewise LONG Data Type

Earlier versions of gateways had limited support for the LONG data type. LONG is an Oracle data type that can store up to 2 GB of character data or raw data (LONG RAW). These earlier versions restricted the amount of LONG data to 4 MB because they treated LONG data as a single piece. This caused memory and network bandwidth restrictions on the size of the data that could be handled. Current gateways extended the functionality to support the full 2 GB of heterogeneous LONG data. The gateways now manage the data piecewise between the agent and Oracle Database, eliminating the large memory and network bandwidth requirements.

The HS_LONG_PIECE_TRANSFER_SIZE Heterogeneous Services initialization parameter can be used to set the size of the transferred pieces. For example, consider retrieving 2 GB of LONG data from a heterogeneous source. A smaller piece requires less memory, but it requires more round-trips to retrieve all the data. A larger piece requires fewer round-trips, but it requires a larger amount of memory to store the intermediate pieces internally. The initialization parameter can be used to tune a system for the best performance, that is, for the best trade-off between round-trips and memory requirements. If the initialization parameter is not set, the system uses 64 KB as the default piece size.


Note:

Do not confuse this feature with piecemeal operations on LONG data on the client side. Piecemeal fetch and insert operations on the client side worked with the earlier versions of the gateways, and they continue to do so. The only difference on the client side is that, where earlier versions of the gateways were able to fetch a maximum of 4 MB of LONG data, now they can retrieve the 2 GB of LONG data. This is a significant improvement because 4 MB is only 0.2 percent of the data type's capacity.

3.9 SQL*Plus DESCRIBE Command

You can describe non-Oracle system objects using the SQL*Plus DESCRIBE command. However, there are some limitations. For example, using heterogeneous links, you cannot describe packages, sequences, synonyms, or types.

3.10 Constraints on SQL in a Distributed Environment

This section explains some of the constraints on SQL in a distributed environment. These constraints apply to distributed environments that access non-Oracle systems or remote Oracle databases.

This section contains the following topics:

  • Remote and Heterogeneous References

  • Important Restrictions

3.10.1 Remote and Heterogeneous References


Note:

Many of the rules for heterogeneous access also apply to remote references. For more information, see the distributed database section of the Oracle Database Administrator's Guide.

A statement can, with restrictions, be executed on any database node referenced in the statement or the local node. If all objects referenced are resolved to a single, referenced node, Oracle attempts to execute a query at that node. You can force execution at a referenced node by using the /*+ REMOTE_MAPPED */ or /*+ DRIVING_SITE */ hints. If a statement is forwarded to a node other than the node from where the statement was issued, the statement is said to be remote-mapped.

There is complete data type checking support for remote-mapped statements. The result provides consistent data type checking and complete data type coercion.


See Also:

Section 4.5, "Oracle Database Server SQL Construct Processing"

The ways in which statements can be remote-mapped are subject to specific rules or restrictions. If these rules are not followed, an error occurs. As long as the statements issued are consistent with all these rules, the order in which the rules are applied does not matter. See Section 3.10.2 for these rules or restrictions.

Different constraints exist when you are using SQL for remote mapping in a distributed environment. This distributed environment can include remote Oracle databases as well as non-Oracle databases that are accessed through Oracle Database gateways.

3.10.2 Important Restrictions

The following section lists some of the different rules or restrictions that exist when you are using SQL for remote mapping in a distributed environment.


Note:

In the examples that follow, remote_db refers to a remote non-Oracle system while remote_oracle_db refers to a remote Oracle Database.

Rule A: A data definition language statement cannot be remote-mapped.

In Oracle data definition language, the target object syntactically has no place for a remote reference. Data definition language statements that contain remote references are always executed locally. For Heterogeneous Services, this means it cannot directly create database objects in a non-Oracle database using SQL.

However, there is an indirect way using passthrough SQL as shown in the following example:

DECLARE
  num_rows INTEGER;
BEGIN 
  num_rows := DBMS_HS_PASSTHROUGH.EXECUTE_IMMEDIATE@remote_db 
  (
     'create table x1 (c1 char, c2 int)'
  ); 
END; 

Rule B: INSERT, UPDATE and DELETE statements with a remote target table must be remote-mapped.

This rule is more restrictive for non-Oracle remote databases than for a remote Oracle database. This is because the remote system cannot fetch data from the originating Oracle database while executing data manipulation language (DML) statements targeting tables in a non-Oracle system.

For example, to insert all local employees from the local emp table to a remote non-Oracle emp table, use the following statement:

INSERT INTO emp@remote_db SELECT * FROM emp;

This statement is remote-mapped to the remote database. The remote-mapped statement sent to the remote database contains a remote reference back to the originating database for emp. Such a remote link received by the remote database is called a callback link.


Note:

Even though callback links are supported in generic Heterogeneous Services, they may not be implemented in all Heterogeneous Services agents. Refer to your database gateway documentation to determine if callback links work with the database gateway that you are using.

If callback links are not supported by a particular gateway, the previous INSERT statements returns the following error:

ORA-02025: all tables in the SQL statement must be at the remote database

The workaround is to write a PL/SQL block. For example:

DECLARE 
CURSOR remote_insert IS SELECT * FROM emp;
BEGIN 
   FOR rec IN remote_insert LOOP
    INSERT INTO emp@remote_db (empno, ename, deptno) VALUES (
      rec.empno,
      rec.ename, 
      rec.deptno 
    );  
   END loop;
END;

Another special case involves session-specific SQL functions such as USER, USERENV, and SYSDATE. These functions need to be executed at the originating site. A remote-mapped statement containing these functions contains a callback link. For a non-Oracle database for which callbacks are not supported, this can (by default) result in a restriction error.

For example, consider the following statement:

DELETE FROM emp@remote_db WHERE hiredate > sysdate;

The previous statement returns the following error message:

ORA-02070: database REMOTE_DB does not support special functions in this context 

This can be resolved by replacing special functions with a bind variable. For example:

DELETE FROM emp@remote_db WHERE hiredate > :1;

Rule C: Object features like tables with nested table columns, ADT columns, Opaque columns, or Ref Columns cannot be remote-mapped.

Currently, these column types are not supported for heterogeneous access. Hence, this limitation is not directly encountered.

Rule D: SQL statements containing operators and constructs that are not supported at the remote site cannot be remote-mapped.

In the case of an INSERT, UPDATE, or DELETE, this means that the SQL statement cannot be executed (see Rule B). However, you might still be able to execute the SQL statement if the unsupported operator or construct can be executed through a callback link.

In the case of a SELECT, you can always execute a statement affected by this rule as long as none of the remaining rules require the statement to be remote mapped. The SELECT statements affected by this rule are executed by fetching all the necessary data through a remote SELECT operation, and processing the unsupported operator or construct locally using the local SQL engine.

A remote SELECT operation is the operation that retrieves rows from the remote table as opposed to an operation that retrieves data from the local table. In the worse possible case of a remote SELECT, Oracle does a full table scan. A full table scan is a fetch of all the data in the remote table across the network without any filtering (for example, SELECT * FROM EMP).

Full table scans are expensive and, therefore, Oracle attempts to avoid them. If there are indexes on the remote table that can be used, these indexes are used in a WHERE clause predicate to reduce the number of rows fetched across the network.

You can check the SQL statement generated by Oracle Database by explaining the statement and querying the OTHER column of the explain plan table for each REMOTE operation.


See Also:

Section 3.11.1 for more information on how to interpret explain plans with remote references

For example, consider the following statement:

SELECT COUNT(*) FROM emp@remote_db WHERE hiredate < sysdate;

The statement returns the following output:

COUNT(*)  
----------
        14
1 row selected.

The remote table scan is:

SELECT hiredate FROM emp;

The predicate converted to a filter cannot be generated back and passed down to the remote operation because sysdate is not supported by the remote_db or evaluation rules. Thus sysdate must be executed locally.


Note:

Because the remote table scan operation is only partially related to the original query, the number of rows retrieved can be significantly larger than expected and can have a significant impact on performance.

Rule E: SQL statement containing a table expression cannot be remote-mapped.

This limitation is not directly encountered because table expressions are not supported in the heterogeneous access module.

Rule F: If a SQL statement selects LONG data, the statement must be mapped to the node where the table containing the LONG data resides.

Consider the following type of statement:

SELECT long1 FROM table_with_long@remote_db, dual; 

The previous statement returns the following error message (if callback links are not supported):

ORA-02025: all tables in the SQL statement must be at the remote database

Rule G: The statement must be mapped to the node on which the table or tables with columns referenced in the FOR UPDATE OF clause resides when the SQL statement is of form "SELECT...FOR UPDATE OF..."

When the SQL statement is of the form SELECT...FOR UPDATE OF..., the statement must be mapped to the node on which the table or tables with columns referenced in the FOR UPDATE OF clause resides.

For example, consider the following statement:

SELECT ename FROM emp@remote_db WHERE hiredate < sysdate FOR UPDATE OF empno;

The previous statement returns the following error message if it cannot be remote-mapped:

ORA-02070: database REMOTE_DB does not support special functions in this context 

Rule H: If the SQL statement contains a SEQUENCE or sequences, then the statement must be mapped to the site where each sequence resides.

This rule is not encountered for the heterogeneous access module because remote non-Oracle sequences are not supported.

Rule I: If the statement contains a user-defined operator or operators, then the statement must be mapped to the node where each operator is defined.

If the statement contains a user-defined operator, the entire statement needs to be remote-mapped to the database node where the operator is defined.

Rule J: A statement containing duplicate bind variables cannot be remote-mapped.

The workaround for this restriction is to use unique bind variables and bind by number.

3.11 Oracle's Optimizer and Heterogeneous Services

Oracle's optimizer can be used with Heterogeneous Services. Heterogeneous Services collects certain table and index statistics information on the respective non-Oracle system tables and passes this information back to Oracle Database. The Oracle cost-based optimizer uses this information when building the query plan.

There are several other optimizations that the cost-based optimizer performs. The most important ones are remote sort elimination and remote joins.

This section contains the following topics:

  • Example: Using Index and Table Statistics

  • Example: Remote Join Optimization

  • Optimizer Restrictions for Non-Oracle Access

3.11.1 Example: Using Index and Table Statistics

Consider the following statement where you create a table in the Oracle database with 10 rows:

CREATE TABLE T1 (C1 number);

Analyze the table using the DBMS_STATS package. For example:

DBMS_STATS.GATHER_TABLE_STATS ('SCOTT','T1');
DBMS_STATS.GENERATE_STATS ('SCOTT','T1');

The preceding example assumes the schema name is SCOTT and the table name is T1. See the Oracle Database PL/SQL Packages and Types Reference for more information about the DBMS_STATS package.

Create a table in the non-Oracle system with 1000 rows.

Issue the following SQL statement:

SELECT a.* FROM remote_t1@remote_db a, T1 b 
    WHERE a.C1 = b.C1;

The Oracle optimizer issues the following SQL statement to the agent:

SELECT C1 FROM remote_t1@remote_db;

This fetches all 1000 rows from the non-Oracle system and performs the join in the Oracle database.

If we add a unique index on the column C1 in the table remote_t1, and issue the same SQL statement again, the agent receives the following SQL statement for each value of C1 in the local t1:

...
SELECT C1 FROM remote_t1@remote_db WHERE C1 = ?;
...

Note:

? is the bind parameter marker. Also, join predicates containing bind variables generated by Oracle are generated only for nested loop join methods.

To verify the SQL execution plan, generate an explain plan for the SQL statement. First, load utlxplan in the admin directory.

Enter the following:

EXPLAIN PLAN FOR SELECT a.* FROM remote_t1@remote_db a, T1 b 
    WHERE a.C1 = b.C1;

Execute the utlxpls utility script by entering the following statement.

@utlxpls

OPERATION REMOTE indicates that remote SQL is being referenced.

To find out what statement is sent, enter the following statement:

SELECT ID, OTHER FROM PLAN_TABLE WHERE OPERATION = 'REMOTE';

3.11.2 Example: Remote Join Optimization

The following is an example of the remote join optimization capability of the Oracle database.


Note:

The explain plan that uses tables from a non-Oracle system can differ from similar statements with local or remote Oracle table scans. This is because of the limitation on the statistics available to Oracle for non-Oracle tables. Most importantly, column selectivity is not available for non-unique indexes of non-Oracle tables. Because of the limitation of the statistics available, the following example is not necessarily what you encounter when doing remote joins and is intended for illustration only.

Consider the following example:

EXPLAIN PLAN FOR
SELECT e.ename, d.dname, f.ename, f.deptno FROM
   dept d,
   emp@remote_db e,
   emp@remote_db f
 WHERE e.mgr = f.empno
  AND e.deptno = d.deptno 
  AND e.empno = f.empno;
  
@utlxpls

You should see output similar to the following:

PLAN_TABLE_OUTPUT
--------------------------------------------------------------------------------

---------------------------------------------------------------------------
| Id    | Operation                           | Name  | Rows  | Bytes  | Cost
| Inst  |IN-OUT|
---------------------------------------------------------------------------
|   0   | SELECT STATEMENT   |                |  2000   |   197K|   205 |
|*  1   | HASH JOIN          |                |  2000   |   197K|
205 |
|   2   | TABLE ACCESS FULL  | DEPT           |  21     |   462 |     2 |
|*  3   | HASH JOIN          |                |  2000   |   154K|
201 |
|   4   | REMOTE             |                |  2000   | 66000 
|    52 |
|   5   | REMOTE             |                |  2000   | 92000
|    52 |
---------------------------------------------------------------------------

PLAN_TABLE_OUTPUT
---------------@	-----------------------------------------------------------------

Query Block Name / Hint Alias (identified by operation id):
-----------------------------------------------------------

   1 - sel$1 / D
   2 - sel$1 / D
   3 - sel$1 / F
   4 - sel$1 / F
   5 - sel$1 / E

Predicate Information (identified by operation id):

PLAN_TABLE_OUTPUT
--------------------------------------------------------------------------------

---------------------------------------------------

   1 - access("E"."DEPTNO"="D"."DEPTNO")
   3 - access("E"."MGR"="F"."EMPNO" AND "E"."EMPNO"="F"."EMPNO")

Issue the following statement:

SET long 300
SELECT other FROM plan_table WHERE operation = 'REMOTE'; 

You should see output similar to the following:

OTHER
--------------------------------------------------------------------------------

SELECT "EMPNO","ENAME","DEPTNO" FROM "EMP"
SELECT "EMPNO","ENAME","MGR","DEPTNO" FROM "EMP"
SELECT "EMPNO","ENAME","DEPTNO" FROM "EMP"
SELECT "EMPNO","ENAME","MGR","DEPTNO" FROM "EMP"

3.11.3 Optimizer Restrictions for Non-Oracle Access

The following are optimizer restrictions for non-Oracle system access:

  • There are no column statistics for remote objects. This can result in poor execution plans. Verify the execution plan and use hints to improve the plan.

  • There is no optimizer hint to force a remote join. However, there is a remote query block optimization that can be used to rewrite the query slightly in order to get a remote join.

    The example from the previous section can be rewritten to the following form:

        SELECT v.ename, d.dname, d.deptno FROM dept d,
            (SELECT /*+ NO_MERGE */ 
             e.deptno deptno, e.ename ename emp@remote_db e, emp@remote_db f
                 WHERE e.mgr = f.empno
                 AND e.empno = f.empno;
            )
          WHERE v.deptno = d.deptno;
    
    
    

This example guarantees a remote join because it has been isolated in a nested query with the NO_MERGE hint.

PKX}[O @ PKr>A OEBPS/lot.htm& List of Tables PK1 +&PKr>AOEBPS/trouble.htm Performance Recommendations

5 Performance Recommendations

This chapter suggests ways to optimize distributed SQL statements and improve the performance of distributed queries.

This chapter includes the following sections:

5.1 Optimizing Heterogeneous Distributed SQL Statements

When a SQL statement accesses data from non-Oracle systems, it is said to be a heterogeneous distributed SQL statement. To optimize heterogeneous distributed SQL statements, follow the same guidelines as for optimizing distributed SQL statements that access Oracle databases only. However, you must consider that the non-Oracle system usually does not support all the functions and operators that Oracle supports.

The Oracle Database gateways tell Oracle (at connect time) which functions and operators they support. If the non-Oracle data source does not support a function or operator, then Oracle performs that function or operator. In this case, Oracle obtains the data from the other data source and applies the function or operator locally. This affects the way in which the SQL statements are decomposed and can affect performance, especially if Oracle is not on the same computer as the other data source. However, performance can be improved if you use the bulk fetch and bulk load features.

5.2 Optimizing Performance of Distributed Queries

You can improve the performance of distributed queries by using the following strategies:

  • Choose the best SQL statement.

    In many cases, there are several SQL statements that can achieve the same result. If all tables are on the same database, then the difference in performance between these SQL statements may be minimal. If the tables are located on different databases, then the difference in performance may be more significant. Also, note that the best SQL statement may change from one release to the next.

  • Use the query optimizer.

    The query optimizer uses indexes on remote tables, considers more execution plans than the rule-based optimizer, and generally gives better results. With the query optimizer, performance of distributed queries is generally satisfactory. Only on rare occasions is it necessary to change SQL statements, create views, or use procedural code.

  • Use views.

    In some situations, views can be used to improve performance of distributed queries. For example:

    • Joining several remote tables on the remote database

    • Sending a different table through the network

    • Retrieve data from the remote table in parallel

  • Use procedural code.

    On rare occasions, it can be more efficient to replace a distributed query by procedural code, such as a PL/SQL procedure or a precompiler program.

PK\=PK r>Aoa,mimetypePKr>AAzͷb]:iTunesMetadata.plistPKr>AYuMETA-INF/container.xmlPKr>A[pTO OEBPS/cover.htmPKr>AP OEBPS/whatsnew.htmPKr>A0?MM#OEBPS/tgvsgc.htmPKr>A% qOEBPS/title.htmPKr>A A33(OEBPS/intro.htmPKr>An- -1OEBPS/admin.htmPKr>AlY9OEBPS/preface.htmPKr>AoDDOEBPS/index.htmPKr>A{*IppGOEBPS/img/heter009.gifPKr>A{xHZ,,OEBPS/img/heter002.gifPKr>ASS%E#@# OEBPS/img/heter006.gifPKr>Ad?NN OEBPS/img/heter008.gifPKr>AL̄JJgXOEBPS/img/heter007.gifPKr>A3Sh݂¢OEBPS/img/heter010.gifPKr>AZ/*%OEBPS/img_text/heter010.htmPKr>Av85e(OEBPS/img_text/heter006.htmPKr>A=@+OEBPS/img_text/heter002.htmPKr>A-[4/n.OEBPS/img_text/heter005.htmPKr>AA/,'1OEBPS/img_text/heter008.htmPKr>Ald_`4OEBPS/img_text/heter011.htmPKr>AP :OEBPS/img_text/heter009.htmPKr>A ,)$N=OEBPS/img_text/heter007.htmPKr>A]?OEBPS/img_text/heter004.htmPKr>AZ COEBPS/cvrspine.htmPKr>A$a EIOEBPS/toc.ncxPKr>A*LJbTOEBPS/content.opfPKr>A?tձ (tOEBPS/lof.htmPKr>A_ {OEBPS/dcommon/prodbig.gifPKr>AY@ iOEBPS/dcommon/doclib.gifPKr>A9iXkwfwOEBPS/dcommon/oracle-logo.jpgPKr>AtOEBPS/dcommon/contbig.gifPKr>A_OEBPS/dcommon/darbbook.cssPKr>AMά""!OEBPS/dcommon/O_signature_clr.JPGPKr>APz #OEBPS/dcommon/feedbck2.gifPKr>A-/%OEBPS/dcommon/feedback.gifPKr>Aː5D,OEBPS/dcommon/booklist.gifPKr>AN61-OEBPS/dcommon/cpyr.htmPKr>A!:3.!@OEBPS/dcommon/masterix.gifPKr>AeӺ1,AOEBPS/dcommon/doccd.cssPKr>A7 DOEBPS/dcommon/larrow.gifPKr>A#9FOEBPS/dcommon/indxicon.gifPKr>AS'"HOEBPS/dcommon/leftnav.gifPKr>Ahu,JOEBPS/dcommon/uarrow.gifPKr>Al-OJ-MOEBPS/dcommon/oracle.gifPKr>A(UOEBPS/dcommon/index.gifPKr>AGC WOEBPS/dcommon/bookbig.gifPKr>AJV^(aOEBPS/dcommon/rarrow.gifPKr>A枰pkCcOEBPS/dcommon/mix.gifPKr>Ao"nR M eOEBPS/dcommon/doccd_epub.jsPKr>Av I pOEBPS/dcommon/toc.gifPKr>A r~$qOEBPS/dcommon/topnav.gifPKr>A1FAHsOEBPS/dcommon/prodicon.gifPKr>A3( # vOEBPS/dcommon/bp_layout.cssPKr>Ax[?:GOEBPS/dcommon/bookicon.gifPKr>Ap*c^ΉOEBPS/dcommon/conticon.gifPKr>AʍyOEBPS/dcommon/blafdoc.cssPKr>A+&xOEBPS/dcommon/rightnav.gifPKr>Aje88OEBPS/dcommon/oracle-small.JPGPKr>Aއ{&!,OEBPS/dcommon/help.gifPKr>A؏Cc8^8 OEBPS/toc.htmPKr>AX}[O @ 4OEBPS/majfeat.htmPKr>A1 +& "OEBPS/lot.htmPKr>A\=()OEBPS/trouble.htmPKBBi=