Programming with SQL Relay using ODBC
The SQL Relay distribution provides an ODBC driver, enabling applications which use ODBC to access SQL Relay.
Unix/Linux
On Unix or Linux platforms, using unixODBC or iODBC, you can create an instance for the SQL Relay driver by adding an entry like the following to your ODBC instances file (usually /etc/odbcinst.ini)
[SQLRelay] Description=ODBC for SQL Relay Driver=/usr/local/firstworks/lib/libsqlrodbc.so FileUsage=0
Note that the Driver attribute must bet set to the full pathname of the libsqlrodbc.so driver. Note also that on Mac OS X you'll need to replace the .so suffix with .dylib
Once the instance is defined you can add a DSN for SQL Relay by adding an entry like the following to your ODBC INI file (usually /etc/odbc.ini)
[sqlrexample] Description=Connection to SQL Relay Driver=SQLRelay Server=sqlrserver Port=9000 Socket=/tmp/example.socket User=exampleuser Password=examplepass
Here the Driver attribute refers to the instance in odbcinst.ini.
Alternatively, you could create a combined instance/DSN by adding an entry like the following to your ODBC INI file (usually /etc/odbc.ini)
[sqlrexample] Description=Connection to SQL Relay Driver=/usr/local/firstworks/lib/libsqlrodbc.so FileUsage=0 Server=sqlrserver Port=9000 Socket=/tmp/example.socket User=exampleuser Password=examplepass
Windows
On Windows, just use the ODBC control panel to create a DSN.
Attributes
The following attributes can be configured:
- Description - A user-friendly description of this configuration.
- Driver
- In the odbc.ini file - The name of the section of the odbcinst.ini file that specifies which driver library to use. If an odbc.ini file is being used but no odbcinst.ini file is being used, then this is the file name of the driver library to use.
- In the odbcinst.ini file - The file name of the driver library to use.
- This parameter is not available via the Windows control panel because the driver name is configured during installation and the parameter is hardcoded to the correct value for each instance.
- FileUsage - Always set to 0. 0 indicates that the driver is an RDBMS driver. 1 means that each file is a table (eg. Xbase). 2 means that each file is an entire database (eg. Access). This parameter is not available via the Windows control panel because it is configured during installation.
- Server - The SQL Relay server to connect to. If Server is a comma-separated list of hosts, then an attempt will be made to connect to each until the attempt succeeds, or there are no more hosts left to try.
- Port - The port that the SQL Relay server is listening on. Either port or socket must be specified. If both are specified, socket will be preferred to port.
- Socket - The socket that the SQL Relay server is listening on. Either port or socket must be specified. If both are specified, socket will be preferred to port.
- User - The username to use when logging into SQL Relay.
- Password - The password to use when logging into SQL Relay.
- Tries - If a connection fails, it will be retried this many times.
- RetryTime - If a connection fails, it will be retried on this interval (in seconds).
- Db - The database to switch to when logging into SQL Relay. May be left empty or omitted to accept the default database that SQL Relay is already connected to.
- Debug - If this is set to 1 or to a file name then debug is enabled. If set to a file name then debug will be written to the file. If set to 1 then debug will be written to standard output. Defaults to 0.
- ResultSetBufferSize - Sets the number of rows to buffer at a time. If set to 0 (the default) then the entire result set is buffered.
- NOTE: This parameter is dangerous to set and probably shouldn't be set unless you wrote the application and know that it is safe to set. ResultSetBufferSize basically sets SQL_ROWSET_SIZE, but apps generally assume that SQL_ROWSET_SIZE is set to 1 unless they explicitly set it to something else. If ResultSetBufferSize is set to something other than 0 or 1, and the app assumes that SQL_ROWSET_SIZE is 1 then the app will only fetch the first row of each rowset.
- ColumnNameCase - Indicates the case to convert column names to. May be set to "mixed", "upper", or "lower". Defaults to "mixed".
- DontGetColumnInfo - If this is set to 1 then column info is not fetched with the result set. If set to 0 then column info is fetched. Defaults to 0.
- NullsAsNulls - If this is set to 1 then NULL values are returned as NULLs. If set to 0 then NULL values are returned as empty strings. Defaults to 0.
- LazyConnect - By default, the SQL Relay client does "lazy connects". I.e. the connection to the SQL Relay server isn't established until the first query or other operation is run. This optimizes availability of the connection pool but is inconstent with most other database API's. Setting this parameter to 0 causes the connection to the SQL Relay server to be established immediately and the constructor to fail, returning undef, if the connection cannot be established. Defaults to 1.
The following attributes can be used to establish Kerberos or Active Directory encryption and authentication with the server:
See the SQL Relay Configuration Guide for more information about Kerberos and Active Directory configurations. In particular, User and Password are not typically used when using Kerberos/AD.
- Krb - Set to yes to enable Kerberos/AD encryption/authentication or no to disable it.
- Krbservice - Specifies the Kerberos service name of the SQL Relay server. If omitted or left empty then the service name "sqlrelay" will be used. "sqlrelay" is the default service name of the SQL Relay server. Note that on Windows platforms the service name must be fully qualified, including the host and realm name. For example: "sqlrelay/sqlrserver.firstworks.com@AD.FIRSTWORKS.COM".
- Krbmech - Specifies the Kerberos mechanism to use. On Linux/Unix platforms, this should be a string representation of the mechnaism's OID, such as: { 1 2 840 113554 1 2 2 }. On Windows platforms, this should be a string like: Kerberos. If omitted or left empty then the default mechanism will be used. Only set this if you know that you have a good reason to.
- Krbflags - Specifies what Kerberos flags to use. Multiple flags may be specified, separated by commas. If left empty or NULL then a defalt set of flags will be used. Only set this if you know that you have a good reason to. Valid flags include: GSS_C_MUTUAL_FLAG, GSS_C_REPLAY_FLAG, GSS_C_SEQUENCE_FLAG, GSS_C_CONF_FLAG, and GSS_C_INTEG_FLAG. For a full list of flags, consult the GSSAPI documentation, though note that only the previously listed flags are supported on Windows.
The following attributes can be used to establish TLS/SSL encryption and authentication with the server:
See the SQL Relay Configuration Guide for more information about TLS/SSL configurations.
- Tls - Set to yes to enable TLS/SSL encryption/authentication or no to disable it.
- Tlsversion - Specifies the TLS/SSL protocol version that the client will attempt to use. Valid values include SSL2, SSL3, TLS1, TLS1.1, TLS1.2 or any more recent version of TLS, as supported by and enabled in the underlying TLS/SSL library. If omittted or left empty then the highest supported version will be negotiated.
- Tlscert - Specifies the file name of the certificate chain file to send to the SQL Relay server. This is only necessary if the SQL Relay server is configured to authenticate and authorize clients by certificate.
- Tlspassword - If Tlscert contains a password-protected private key, then Tlspassword may be supplied to access it. If the private key is not password-protected, then this argument is ignored, and may be omitted or left empty.
- Tlsciphers - Specifies a list of ciphers to allow. Ciphers may be separated by spaces, commas, or colons. If omitted or left empty then a default set is used. For a list of valid ciphers on Linux/Unix platforms, see: man ciphers. For a list of valid ciphers on Windows platforms, see this page. On Windows platforms, the ciphers (alg_id's) should omit CALG_ and may be given with underscores or dashes. For example: 3DES_112. Only set this if you know that you have a good reason to.
- Tlsvalidate - Indicates whether to validate the SQL Relay server's certificate, and may be set to one of the following: no - Don't validate the server's certificate. ca - Validate that the server's certificate was signed by a trusted certificate authority. ca+host - Perform "ca" validation and also validate that one of the subject altenate names (or the common name if no SANs are present) in the certificate matches the host parameter. (Falls back to "ca" validation when a unix socket is used.) ca+domain - Perform "ca" validation and also validate that the domain name of one of the subject alternate names (or the common name if no SANs are present) in the certificate matches the domain name of the host parameter. (Falls back to "ca" validation when a unix socket is used.)
- Tlsca - Specifies the location of a certificate authority file to use, in addition to the system's root certificates, when validating the SQL Relay server's certificate. This is useful if the SQL Relay server's certificate is self-signed. On Windows, "ca" must be a file name. On non-Windows systems, "ca" can be either a file or directory name. If it is a directory name, then all certificate authority files found in that directory will be used. If it a file name, then only that file will be used.
Note that the supported Tlscert and Tlsca file formats may vary between platforms. A variety of file formats are generally supported on Linux/Unix platfoms (.pem, .pfx, etc.) but only the .pfx format is currently supported on Windows.
Sample Session
Now you can use the isql command line utility that comes with iODBC or unixODBC to access the database through SQL Relay as follows:
isql sqlrexample
Here is a sample session:
[dmuse@fedora ~]$ isql sqlrodbc +---------------------------------------+ | Connected! | | | | sql-statement | | help [tablename] | | quit | | | +---------------------------------------+ SQL> create table exampletable (col1 int, col2 varchar2(20)) SQLRowCount returns 0 SQL> insert into exampletable values (1,'hello') SQLRowCount returns 1 SQL> insert into exampletable values (2,'goodbye') SQLRowCount returns 1 SQL> select * from exampletable +-----+--------+ | COL1| COL2 | +-----+--------+ | 1 | hello | | 2 | goodbye| +-----+--------+ SQLRowCount returns 0 2 rows fetched SQL> update exampletable set col2='bye' where col1=2 SQLRowCount returns 1 SQL> select * from exampletable +-----+------+ | COL1| COL2 | +-----+------+ | 1 | hello| | 2 | bye | +-----+------+ SQLRowCount returns 0 2 rows fetched SQL> delete from exampletable SQLRowCount returns 2 SQL> select * from exampletable +-----+-----+ | COL1| COL2| +-----+-----+ +-----+-----+ SQLRowCount returns 0 SQL> drop table exampletable SQLRowCount returns 0 SQL> quit [dmuse@fedora ~]$
If you get an error like ISQL ERROR: Could not SQLConnect when you run isql then it's possible that it can't find your ODBC INI file. Some versions of unixODBC, when compiled and installed with non-standard prefixes, still look for odbc.ini in /etc rather than under their prefix. For example, I discovered that on Mac OS X, unixODBC 2.2.12 installed under /sw should look for /sw/etc/odbc.ini but instead it looks for /etc/odbc.ini, even though odbcinst -j looks under /sw.
You can work around this by setting environment variables to override whatever default search path unixODBC uses. For example, to force it to look under /sw/etc, use:
export ODBCINST=/sw/etc/odbcinst.ini export ODBCINI=/sw/etc/odbc.ini
Any program that uses ODBC can be configured to use SQL Relay via ODBC by setting its DSN to the SQL Relay DSN that you defined.
You can also use SQL Relay with any language that supports ODBC directly or has a database abstraction layer that supports ODBC. For example, lets say you have an existing PHP app that uses MDB2 to connect to Oracle and you want to use SQL Relay with it. There is no PHP MDB2 driver for SQL Relay, but since MDB2 suppots ODBC, you could use:
PHP -> MDB2 -> ODBC -> SQL Relay -> Oracle
Similarly, you could use SQL Relay via ODBC with PHP/PDO, PHP/ADODB, Java/JDBC (using the JDBC-ODBC bridge), with the ODBC Adapter for Ruby on Rails, and so on.
Developing applications which use ODBC is beyond the scope if this document but many examples and tutorials can be found on the web.