%META:TOPICPARENT{name="SingleTierExpressInstallMac"}%
= Installation and Configuration of the Single-Tier "Express" Edition ODBC Driver for Ingres Data Sources, for Mac OS X=
**Review Preinstallation Documentation:**  [[PreInstallIngresExpressOSX|Pre-Installation Requirements]]
%TOC%
==Installation==
Note: The software must be installed as a user with Administrative privileges on the machine.
# The Single-Tier "Express" Edition ODBC Driver for Ingres Data Sources is distributed as a Disk Image ({{{.dmg}}}) file:  
%BR%%BR% %BR%%BR%
# Double-click the disk image 'mul6eing.dmg' to access the installer {{{.mpkg}}} file:
%BR%%BR%
%BR%%BR%
# Double-click the disk image 'mul6eing.dmg' to access the installer {{{.mpkg}}} file:
%BR%%BR% %BR%%BR%
# Double-click the {{{.mpkg}}} file to run the installer and follow the instructions to complete the installation:
%BR%%BR%
%BR%%BR%
# Double-click the {{{.mpkg}}} file to run the installer and follow the instructions to complete the installation:
%BR%%BR% %BR%%BR%
# This is the **Welcome** dialog for the OpenLink ODBC Driver for Ingres (Express Edition):
%BR%%BR%
%BR%%BR%
# This is the **Welcome** dialog for the OpenLink ODBC Driver for Ingres (Express Edition):
%BR%%BR% %BR%%BR%
# Review the **Read Me** file for installation requirements and known issues:
%BR%%BR%
%BR%%BR%
# Review the **Read Me** file for installation requirements and known issues:
%BR%%BR% %BR%%BR%
# Read the **Software License Agreement** before continuing your installation:
%BR%%BR%
%BR%%BR%
# Read the **Software License Agreement** before continuing your installation:
%BR%%BR% %BR%%BR%
# Select a destination volume for the driver installation:
%BR%%BR%
%BR%%BR%
# Select a destination volume for the driver installation:
%BR%%BR% %BR%%BR%
# Choose to perform a custom or default installation of the driver:
%BR%%BR%
%BR%%BR%
# Choose to perform a custom or default installation of the driver:
%BR%%BR% %BR%%BR%
# If you chose the custom option, select which of the following components to install:
%BR%%BR%
%BR%%BR%
# If you chose the custom option, select which of the following components to install:
%BR%%BR% %BR%%BR%
# Note: The software must be installed as a user with Administrative privileges on the machine:
%BR%%BR%
%BR%%BR%
# Note: The software must be installed as a user with Administrative privileges on the machine:
%BR%%BR% %BR%%BR%
# After the driver has been installed, you will be prompted for a license file. If a license file already exists on the machine, select the 'use existing file' option. A trial (try) or full (buy) license can be obtained by selecting the 'try and buy' option which loads the online try and buy web page:
%BR%%BR%
%BR%%BR%
# After the driver has been installed, you will be prompted for a license file. If a license file already exists on the machine, select the 'use existing file' option. A trial (try) or full (buy) license can be obtained by selecting the 'try and buy' option which loads the online try and buy web page:
%BR%%BR% %BR%%BR%
# To obtain the trial license you must be a registered user on the OpenLink Web site and login with the username (e-mail address) and password for that user. Click on the 'Shop' link to visit the online shop cart to purchase a full license, if required:
%BR%%BR%
%BR%%BR%
# To obtain the trial license you must be a registered user on the OpenLink Web site and login with the username (e-mail address) and password for that user. Click on the 'Shop' link to visit the online shop cart to purchase a full license, if required:
%BR%%BR% %BR%%BR%
# Click on the 'download license' button to obtain an immediate license file and save it to your desktop. Alternatively, mail can be sent to your e-mail address with a link to your OpenLink Data Space (ODS). Here, all trial and full license files will be stored in a specialized Briefcase for download at a later date.
%BR%%BR%
%BR%%BR%
# Click on the 'download license' button to obtain an immediate license file and save it to your desktop. Alternatively, mail can be sent to your e-mail address with a link to your OpenLink Data Space (ODS). Here, all trial and full license files will be stored in a specialized Briefcase for download at a later date.
%BR%%BR% %BR%%BR%
# Select the license file that you want to use for the installation:
%BR%%BR%
%BR%%BR%
# Select the license file that you want to use for the installation:
%BR%%BR% %BR%%BR%
# The installation is complete:
%BR%%BR%
%BR%%BR%
# The installation is complete:
%BR%%BR% %BR%%BR% 
== Configuration ==
# To configure an ODBC DSN, run the OpenLink iODBC Administrator located in the /Applications/iODBC folder:
%BR%%BR%
%BR%%BR% 
== Configuration ==
# To configure an ODBC DSN, run the OpenLink iODBC Administrator located in the /Applications/iODBC folder:
%BR%%BR% %BR%%BR%
# Click the Add button:
%BR%%BR%
%BR%%BR%
# Click the Add button:
%BR%%BR% %BR%%BR%
# Select the OpenLink Ingres Driver (Express Edition) v6.0 from the list of available drivers. Select the Unicode version of the driver **if and only if** you are working with multi-byte character sets, as unnecessary translations can significantly affect ODBC performance:
%BR%%BR%
%BR%%BR%
# Select the OpenLink Ingres Driver (Express Edition) v6.0 from the list of available drivers. Select the Unicode version of the driver **if and only if** you are working with multi-byte character sets, as unnecessary translations can significantly affect ODBC performance:
%BR%%BR% %BR%%BR%
# Provide a suitable DSN name and optional description for the Data Source:
%BR%%BR%
%BR%%BR%
# Provide a suitable DSN name and optional description for the Data Source:
%BR%%BR% %BR%%BR%
# The Connection tab takes the minimum parameters required to make a connection to the target database:
%BR%%BR%
%BR%%BR%
# The Connection tab takes the minimum parameters required to make a connection to the target database:
%BR%%BR% %BR%%BR% 
#* **Hostname** - The hostname of the server on which the Ingres Node is  running
#* **PortName** - The Ingres instance Node name
#* **Database** - The database name of a valid database on the Node
#* **User name** - A valid ingres user name
#* The advanced button displays additional optional parameters that can be configured.
|**Name**|** Description**|  
| **RoleName** | Role used in DBMS.| 
| **GroupName** | Group used in DBMS. |
| **DbmsUser** | User ID for the DBMS session (-u flag). | 
| **DbmsPassword** | User's DBMS password. | 
| **ConnectionPool** | Use pooled connection: 'off' or 'on'. | 
| **AutocommitMode** | Autocommit cursor handling: 'dbms', 'single', 'multi' | 
| **SelectLoops** | Select loop processing: 'off' or 'on' | 
| **CursorMode** | Default cursor concurrency mode, which determines the concurrency of cursors that have no concurrency explicitly assigned. Available options are: 'dbms', 'update', 'readonly'. | 
| **VnodeUsage** | Allows the JDBC application to control the portions of the vnode information used to establish connections to the remote DBMS server. Available options are: 'connect', 'login' | 
| **CharEncode** | Specifies the Java character encoding used for conversions between Unicode and character data types. Generally, the character encoding is determined automatically by the driver from the DAS installation character set. This property allows an alternate character encoding to be specified (if desired) or a valid character encoding to be used when the driver is unable to map the server's character set. | 
| **TimeZone** | Specifies the Ingres timezone associated with the client's location. Corresponds to the Ingres environment variable II_TIMEZONE_NAME and is assigned the same values. This property is not used directly by the driver but is sent to the DBMS and affects the processing of dates. | 
| **DecimalChar** | Specifies the character to be used as the decimal point in numeric literals. Corresponds to the Ingres environment variable II_DECIMAL and is assigned the same values. This property is not used directly by the driver but is sent to the DBMS and affects the processing of query text. | 
| **DateFormat** | Specifies the Ingres format for date literals. Corresponds to the Ingres environment variable II_DATE_FORMAT and is assigned the same values. This property is not used directly by the driver but is sent to the DBMS and affects the processing of query text. | 
| **MoneyFormat** | Specifies the Ingres format for money literals. Corresponds to the Ingres environment variable II_MONEY_FORMAT and is assigned the same values. This property is not used directly by the driver but is sent to the DBMS and affects the processing of query text. | 
| **MoneyPrecision** | Specifies the precision of money data values. Corresponds to the Ingres environment variable II_MONEY_PREC and is assigned the same values. This property is not used directly by the driver but is sent to the DBMS and affects the processing of money values. | 
# Click continue to proceed to the Options tab. This tab contains optional parameters that are not required for basic ODBC connectivity:
%BR%%BR%
%BR%%BR% 
#* **Hostname** - The hostname of the server on which the Ingres Node is  running
#* **PortName** - The Ingres instance Node name
#* **Database** - The database name of a valid database on the Node
#* **User name** - A valid ingres user name
#* The advanced button displays additional optional parameters that can be configured.
|**Name**|** Description**|  
| **RoleName** | Role used in DBMS.| 
| **GroupName** | Group used in DBMS. |
| **DbmsUser** | User ID for the DBMS session (-u flag). | 
| **DbmsPassword** | User's DBMS password. | 
| **ConnectionPool** | Use pooled connection: 'off' or 'on'. | 
| **AutocommitMode** | Autocommit cursor handling: 'dbms', 'single', 'multi' | 
| **SelectLoops** | Select loop processing: 'off' or 'on' | 
| **CursorMode** | Default cursor concurrency mode, which determines the concurrency of cursors that have no concurrency explicitly assigned. Available options are: 'dbms', 'update', 'readonly'. | 
| **VnodeUsage** | Allows the JDBC application to control the portions of the vnode information used to establish connections to the remote DBMS server. Available options are: 'connect', 'login' | 
| **CharEncode** | Specifies the Java character encoding used for conversions between Unicode and character data types. Generally, the character encoding is determined automatically by the driver from the DAS installation character set. This property allows an alternate character encoding to be specified (if desired) or a valid character encoding to be used when the driver is unable to map the server's character set. | 
| **TimeZone** | Specifies the Ingres timezone associated with the client's location. Corresponds to the Ingres environment variable II_TIMEZONE_NAME and is assigned the same values. This property is not used directly by the driver but is sent to the DBMS and affects the processing of dates. | 
| **DecimalChar** | Specifies the character to be used as the decimal point in numeric literals. Corresponds to the Ingres environment variable II_DECIMAL and is assigned the same values. This property is not used directly by the driver but is sent to the DBMS and affects the processing of query text. | 
| **DateFormat** | Specifies the Ingres format for date literals. Corresponds to the Ingres environment variable II_DATE_FORMAT and is assigned the same values. This property is not used directly by the driver but is sent to the DBMS and affects the processing of query text. | 
| **MoneyFormat** | Specifies the Ingres format for money literals. Corresponds to the Ingres environment variable II_MONEY_FORMAT and is assigned the same values. This property is not used directly by the driver but is sent to the DBMS and affects the processing of query text. | 
| **MoneyPrecision** | Specifies the precision of money data values. Corresponds to the Ingres environment variable II_MONEY_PREC and is assigned the same values. This property is not used directly by the driver but is sent to the DBMS and affects the processing of money values. | 
# Click continue to proceed to the Options tab. This tab contains optional parameters that are not required for basic ODBC connectivity:
%BR%%BR% #*  **Row Buffer Size ** - This attribute specifies the number of records to be transported over the network in a single network hop. Values can range from 1 to 99.
#*  **Hide Login Dialog ** - Suppresses the ODBC "Username" and "Password" login dialog boxes when interacting with your ODBC DSN from within an ODBC compliant application.
#*  **Read Only connection ** - Specifies whether the connection is "Read-only." Make sure the checkbox is unchecked to request a "Read/Write" connection.
#*  **Drop Catalog from Meta calls ** - Enable this option to have the catalog name not appear for tables, views, and procedures when requesting database meta-data.
#*  **No support of quoted identifier ** - If set, the call SQLGetInfo for 'SQL_IDENTIFIER_QUOTE_CHAR' will return a space (" "). It can be used if the DBMS doesn't support quoted SQL like select * from "account."
#*  **Drop Schema from Meta calls ** - Enable this option to have the schema-name not appear for tables, views, and procedures when requesting database meta-data.
#*  **SQLStatistics disabled ** -  Check this box to have SQLStatistics() return an empty resultset. Use this if the underlying database does not support retrieval of statistics about a table (e.g. what indexes it has).
#*   **No support of search string escape ** - If set, the call SQLGetInfo for 'SQL_LIKE_ESCAPE_CLAUSE' will return a space (" "). It can be used if the DBMS doesn't support SQL escape patterns.
#*  **Patch of NULL size of SQL_CHAR ** -  If set, this option overrides the size of SQL_CHAR column type returned by the database with the value set in the text box (in bytes). With a default value of 0, the driver uses the size returned by the database.
#*  **SQL_DBMS Name ** - Manually overrides the SQLGetInfo(SQL_DBMS_NAME) response returned by the driver. This is required for products like Microsoft InfoPath for which the return the value should be "SQL Server".
# Click continue to proceed to the Preferences tab. This tab contains optional parameters that are not required for basic ODBC connectivity:
%BR%%BR%
 
#*  **Row Buffer Size ** - This attribute specifies the number of records to be transported over the network in a single network hop. Values can range from 1 to 99.
#*  **Hide Login Dialog ** - Suppresses the ODBC "Username" and "Password" login dialog boxes when interacting with your ODBC DSN from within an ODBC compliant application.
#*  **Read Only connection ** - Specifies whether the connection is "Read-only." Make sure the checkbox is unchecked to request a "Read/Write" connection.
#*  **Drop Catalog from Meta calls ** - Enable this option to have the catalog name not appear for tables, views, and procedures when requesting database meta-data.
#*  **No support of quoted identifier ** - If set, the call SQLGetInfo for 'SQL_IDENTIFIER_QUOTE_CHAR' will return a space (" "). It can be used if the DBMS doesn't support quoted SQL like select * from "account."
#*  **Drop Schema from Meta calls ** - Enable this option to have the schema-name not appear for tables, views, and procedures when requesting database meta-data.
#*  **SQLStatistics disabled ** -  Check this box to have SQLStatistics() return an empty resultset. Use this if the underlying database does not support retrieval of statistics about a table (e.g. what indexes it has).
#*   **No support of search string escape ** - If set, the call SQLGetInfo for 'SQL_LIKE_ESCAPE_CLAUSE' will return a space (" "). It can be used if the DBMS doesn't support SQL escape patterns.
#*  **Patch of NULL size of SQL_CHAR ** -  If set, this option overrides the size of SQL_CHAR column type returned by the database with the value set in the text box (in bytes). With a default value of 0, the driver uses the size returned by the database.
#*  **SQL_DBMS Name ** - Manually overrides the SQLGetInfo(SQL_DBMS_NAME) response returned by the driver. This is required for products like Microsoft InfoPath for which the return the value should be "SQL Server".
# Click continue to proceed to the Preferences tab. This tab contains optional parameters that are not required for basic ODBC connectivity:
%BR%%BR% #*  **Initialization SQL ** - Lets you specify a file containing SQL statements that will be run automatically against the database upon connection.
#*  **Cursor Sensitivity ** - Enables or disables the row version cache used with dynamic cursors. When dynamic cursor sensitivity is set high, the Cursor Library calculates checksums for each row in the current rowset and compares these with the checksums (if any) already stored in the row version cache for the same rows when fetched previously. If the checksums differ for a row, the row has been updated since it was last fetched and the row status flag is set to SQL_ROW_UPDATED. The row version cache is then updated with the latest checksums for the rowset. From the user's point of view, the only visible difference between the two sensitivity settings is that a row status flag can never be set to SQL_ROW_UPDATED when the cursor sensitivity is low. (The row status is instead displayed as SQL_ROW_SUCCESS.) In all other respects, performance aside, the two settings are the same. Deleted rows don't appear in the rowset. Updates to the row since the row was last fetched are reflected in the row data, and inserted rows appear in the rowset, if their keys fall within the span of the rowset. If your application does not need to detect the row status SQL_ROW_UPDATED, you should leave the 'High Cursor Sensitivity' checkbox unchecked, as performance is improved. The calculation and comparison of checksums for each row fetched carries an overhead. If this option is enabled, the table oplrvc must have been created beforehand using the appropriate script for the target database.
#*  **Max Rows Override ** - Allows you to define a limit on the maximum number of rows to be returned from a query. The default value of 0 means no limit.
#*  **Disable Autocommit ** - Changes the default commit behaviour of the OpenLink driver. The default mode is AutoCommit (box unchecked).
#*  **Disable Rowset Size Limit ** - Disables a limitation enforced by the cursor library. This limitation is enforced by default. It prevents the driver from claiming all available memory in the event that a resultset  generated from an erroneous query is very large. The limit is normally never reached.
#*  **Defer fetching of long data ** - Defers fetching of LONG (BINARY, BLOB etc.) data unless explicitly requested in a query. This provides significant performance increases when fields in query do not include LONG data fields.
#*  **Multiple Active Statements Emulation ** - Enables use of Multiple Active statements in an ODBC application even if the underlying database does not allow this, as it is emulated in the driver.
# Click on the 'Test Data Source' button to make a connection to the database to verify connectivity:
%BR%%BR%
 
#*  **Initialization SQL ** - Lets you specify a file containing SQL statements that will be run automatically against the database upon connection.
#*  **Cursor Sensitivity ** - Enables or disables the row version cache used with dynamic cursors. When dynamic cursor sensitivity is set high, the Cursor Library calculates checksums for each row in the current rowset and compares these with the checksums (if any) already stored in the row version cache for the same rows when fetched previously. If the checksums differ for a row, the row has been updated since it was last fetched and the row status flag is set to SQL_ROW_UPDATED. The row version cache is then updated with the latest checksums for the rowset. From the user's point of view, the only visible difference between the two sensitivity settings is that a row status flag can never be set to SQL_ROW_UPDATED when the cursor sensitivity is low. (The row status is instead displayed as SQL_ROW_SUCCESS.) In all other respects, performance aside, the two settings are the same. Deleted rows don't appear in the rowset. Updates to the row since the row was last fetched are reflected in the row data, and inserted rows appear in the rowset, if their keys fall within the span of the rowset. If your application does not need to detect the row status SQL_ROW_UPDATED, you should leave the 'High Cursor Sensitivity' checkbox unchecked, as performance is improved. The calculation and comparison of checksums for each row fetched carries an overhead. If this option is enabled, the table oplrvc must have been created beforehand using the appropriate script for the target database.
#*  **Max Rows Override ** - Allows you to define a limit on the maximum number of rows to be returned from a query. The default value of 0 means no limit.
#*  **Disable Autocommit ** - Changes the default commit behaviour of the OpenLink driver. The default mode is AutoCommit (box unchecked).
#*  **Disable Rowset Size Limit ** - Disables a limitation enforced by the cursor library. This limitation is enforced by default. It prevents the driver from claiming all available memory in the event that a resultset  generated from an erroneous query is very large. The limit is normally never reached.
#*  **Defer fetching of long data ** - Defers fetching of LONG (BINARY, BLOB etc.) data unless explicitly requested in a query. This provides significant performance increases when fields in query do not include LONG data fields.
#*  **Multiple Active Statements Emulation ** - Enables use of Multiple Active statements in an ODBC application even if the underlying database does not allow this, as it is emulated in the driver.
# Click on the 'Test Data Source' button to make a connection to the database to verify connectivity:
%BR%%BR% %BR%%BR%
# Enter a valid username and password for the database:
%BR%%BR%
%BR%%BR%
# Enter a valid username and password for the database:
%BR%%BR% %BR%%BR%
# A successful connection to the database has been made:
%BR%%BR%
%BR%%BR%
# A successful connection to the database has been made:
%BR%%BR% %BR%%BR%
==Next...==
* [[TestingMacODBCDSNs|Test your DSNs with our sample program]].%BR%%BR%
* If anything isn't working as you expect, including errors resulting from the test above, [[UDATroubleshootingResources|see our Troubleshooting Resources]].%BR%%BR%
* Should you decide to purchase a commercial license at the end of your evaluation period, be sure to consult our documentation which explains the placement and uptake of commercial license files and the use of our OpenLink License Manager technology: [[UDALicenseApplication|License Technology & Application]].
%BR%%BR%
==Next...==
* [[TestingMacODBCDSNs|Test your DSNs with our sample program]].%BR%%BR%
* If anything isn't working as you expect, including errors resulting from the test above, [[UDATroubleshootingResources|see our Troubleshooting Resources]].%BR%%BR%
* Should you decide to purchase a commercial license at the end of your evaluation period, be sure to consult our documentation which explains the placement and uptake of commercial license files and the use of our OpenLink License Manager technology: [[UDALicenseApplication|License Technology & Application]].