After I sent this email I found some of my answers (that always seems to
happen). :-)
Do a WRKRDBDIRE and add an entry that has the db name and host particulars
to point to the right system. If you're using STRSQL for testing, then you
do a "CONNECT TO DBNAME USER <user> USING '<password>'"
If in code, create your db connection handle then connect using:
sqlRet = SQLConnect(cv_hSqlDbc, databaseName, SQL_NTS, user, SQL_NTS,
password, SQL_NTS);
I'm setting a default library with my connection (I'm doing this after the
connect; doesn't seem to be a problem)
sqlRet = SQLSetConnectAttr(cv_hSqlDbc, SQL_ATTR_DBC_DEFAULT_LIB,
(SQLPOINTER)library.c_str(), (SQLINTEGER)library.length());
According to the docs, in order for this to work, you have to set system
naming off (do this step before the above SetConnectAttr()).
SQLINTEGER sysnaming = SQL_FALSE;
SQLPOINTER option;
option = &sysnaming;
sqlRet = SQLSetConnectOption(cv_hSqlDbc, SQL_ATTR_DBC_SYS_NAMING,
option);
This seems to work ok, if I have two connections and then 'ask' what their
default library is, the two report back the correct answers (the default
library is different for each connection).
BUT (with IBM, C++, etc there always seems to be a 'but') - if I do an
unqualified SELECT on a couple of tables, one of the connections is using
the default database of the other connection. I'm trying to figure this out
SQLSelectExecute(local_db, "SELECT * FROM DRIVERS_SNAPSHOT", rows);
SQLSelectExecute(remote_db, "SELECT * FROM UNITS_SNAPSHOT", rows);
In this instance, UNITS_SNAPSHOT is on a remote system and I've set the
default library for it to be DF99328, but the connection information is
trying to use BOBV.
SQLSelectExecute.cpp(67): sqlRet=-1 NativeError=-204 SqlState=42704
Message=UNITS_SNAPSHOT in BOBV type *FILE not found.
This connection should effectively be saying SELECT * FROM
DF99328.UNITS_SNAPSHOT
That's the only thing I need to figure out.
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact
[javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.