This appendix describes only the features of OCI that apply to the Windows 2003, Windows 2000, and Windows XP operating systems. Windows NT is no longer supported.
This chapter contains these topics:
The Oracle Call Interface for Windows package includes:
Oracle Call Interface (OCI)
Oracle Universal Installer
Header files for compiling OCI applications
Library files for linking OCI applications
Sample programs for demonstrating how to build OCI applications
The OCI for Windows package includes the additional libraries required for linking your OCI programs.
See Also:"OCI Instant Client" for a simplified OCI installation option.
When you install OCI, Oracle Universal Installer creates an
ORACLE_BASE\ORACLE_HOME directory on the hard drive of your computer. The default Oracle home directory is
The OCI files are located in the
ORACLE_BASE\ORACLE_HOME directory, as are the library files needed to link and run OCI applications, and link with other Oracle for Windows products, such as Oracle Forms.
ORACLE_BASE\ORACLE_HOME directory contains the following directories that are relevant to OCI:
Executable and help files
Oracle Call Interface directory for Windows files
Header files, such as
Object Type Translator utility and default configuration file
When OCI is installed, a set of sample programs and their corresponding project files are copied to the
\oci\samples subdirectory. Oracle recommends that you build and run these sample programs to verify that OCI has been successfully installed and to familiarize yourself with the steps involved in developing OCI applications.
C:> make cdemo1
After you finish using these sample programs, you can delete them if you choose.
ociucb.c should be compiled using
ociucb.bat. This batch file creates a DLL and places it in the
\bin directory. To load user callback functions, set the environment registry variable
For Microsoft Visual C++, specify
\ORACLE_BASE\ORACLE_HOME\oci\lib\msvc in the libraries section of the Option dialog box. For the Borland compiler, specify
For example, if you are using Microsoft Visual C++ 7.0, you would need to put in the appropriate path,
\oracle\ora10\oci\include, in the Directories page of the Options dialog in the Tools menu.
Note:The only Microsoft Visual C++ releases supported for the current OCI release are 7.0 or higher.
See Also:Your compiler's documentation for specific information about compiling your application and special compiler options
The OCI calls are implemented in dynamic link libraries (DLLs) that Oracle provides. The DLLs are located in the
\bin directory and are part of the Required Support Files (RSFs).
Oracle only provides the
oci.lib import library for use with the Microsoft Compiler. Borland compiler is also supported by Oracle for use with OCI. Oracle recommends that applications must always link with
oci.lib to avoid re-linking or compilation with every release.
oci.lib with the Microsoft Compiler, you do not have to indicate any special link options.
Oracle recommends that applications be linked with
oci.lib, which takes care of loading the correct versions of the Oracle DLLs.
The following directories are searched in this order by
Directory from which the application is loaded or the directory where
oci.dll is located
32-bit Windows system directory
(system32). Use the
GetWindowsDirectory() function to obtain the path of this directory.
16-bit Windows directory
(system). There is no Win32 function that obtains the path of this directory, but it is searched.
Directories that are listed in the PATH environment variable
To run an OCI application, ensure that the entire corresponding set of Required Support Files (RSFs) is installed on the computer that is running your OCI application.
IBM Transarc Encina
You can also use TP monitor statements in your client programs. The use of the XA API is supported from OCI.
The Oracle XA Library is automatically installed as part of Enterprise Edition. Table D-2 lists the components created in your Oracle home directory.
oci.lib now contains the XA exports:
To compile and link an OCI program:
.c by using Microsoft Visual C++ or the Borland compiler, making sure to include
\rdbms\xa in your path.
.obj with the following libraries shown in Table D-3:
The database supports the use of XA dynamic registration. XA dynamic registration improves the performance of applications interfacing with XA-compliant TP monitors. For TP Monitors to use XA dynamic registration with an Oracle database on Windows, you must add either an environmental variable or a registry variable to the Windows computer on which your TP monitor is running. See either of the following sections for instructions:
Adding an environmental variable at the command prompt affects only the current session.
From the computer where your TP monitor is installed, enter the following at the command prompt:
C:\> set ORA_XA_REG_DLL = vendor.dll
.dll is the TP monitor DLL provided by your vendor.
Adding a registry variable affects all sessions on your Windows computer. This is useful for computers where only one TP monitor is running.
Go to the computer where your TP monitor is installed.
Enter the following at the command prompt:
The Registry Editor window appears.
Choose the Add Value option in the Edit menu. The Add Value dialog box appears.
ORA_XA_REG_DLL in the Value Name text box.
REG_EXPAND_SZ from the Datatype list box.
Choose OK. The String Editor dialog box appears.
.dll in the String field, where
.dll is the TP monitor DLL provided by your vendor.
Choose OK. The Registry Editor adds the parameter.
Choose Exit from the Registry menu.
The registry exits.
Distributed TP: The XA Specification (C193) published by the Open Group. The Open Group, 1010 El Camino Real, Suite 380, Menlo Park, CA 94025, U.S.A.
See the Web site at:
Your specific TP monitor documentation
See Also:Oracle Database Application Developer's Guide - Fundamentals "Developing Applications with Oracle XA", for more information about the Oracle XA Library and using XA dynamic registration
To take advantage of objects run OTT against the database, and a header file is generated that includes the C structs. For example, if a
PERSON type has been created in the database, OTT can generate a C struct with elements corresponding to the attributes of
PERSON. In addition, a null indicator struct is created that represents null information for an instance of the C struct.
Note:The INTYPE File Assistant is not available, starting with Oracle Database 10g Release 1.
Note that the
CASE specification inside the
INTYPE files, such as
CASE=LOWER, applies only to C identifiers that are not specifically listed, either through a
TRANSLATE statement in the INTYPE file. It is important to provide the type name with the appropriate cases, such as TYPE
Person and Type
PeRsOn, in the INTYPE file.
OTT on Windows can be invoked from the command line. Additionally, a configuration file may be named on the command line. For Windows, the configuration file is
ottcfg.cfg, located in