[fdo-commits] r2508 - in trunk/Providers/GenericRdbms/Src:
Fdo/Connection ODBC/Fdo UnitTest/Odbc
svn_fdo at osgeo.org
svn_fdo at osgeo.org
Tue Feb 13 13:10:57 EST 2007
Author: romicadascalescu
Date: 2007-02-13 13:10:57 -0500 (Tue, 13 Feb 2007)
New Revision: 2508
Modified:
trunk/Providers/GenericRdbms/Src/Fdo/Connection/DbiConnection.cpp
trunk/Providers/GenericRdbms/Src/Fdo/Connection/DbiConnection.h
trunk/Providers/GenericRdbms/Src/ODBC/Fdo/FdoRdbmsOdbcConnection.cpp
trunk/Providers/GenericRdbms/Src/UnitTest/Odbc/OdbcConnectionUtil.cpp
Log:
Fixed ODBC(Oracle) provider describe schema is slow (ported from branch)
Modified: trunk/Providers/GenericRdbms/Src/Fdo/Connection/DbiConnection.cpp
===================================================================
--- trunk/Providers/GenericRdbms/Src/Fdo/Connection/DbiConnection.cpp 2007-02-13 00:58:47 UTC (rev 2507)
+++ trunk/Providers/GenericRdbms/Src/Fdo/Connection/DbiConnection.cpp 2007-02-13 18:10:57 UTC (rev 2508)
@@ -81,8 +81,7 @@
mFilterProcessor( NULL ),
mSchemaUtil( NULL ),
mIndex(0),
- mContext(NULL),
- mParsedConnection(NULL)
+ mContext(NULL)
{
// Set the flag that indicates whether or not the RDBMS user has a Workspace
// Manager environment.
@@ -92,8 +91,8 @@
// Workspace Manager or Alternate API.
mIsWorkspaceManagerEnvironment = FALSE;
+ mParsedConnection = new ParseInfo();
-
}
DbiConnection::~DbiConnection(void)
@@ -181,8 +180,6 @@
mGdbiConnection->SetIsGeometryFromOrdinatesWanted((char*)(const char*)(mParsedConnection->mIsGeometryFromOrdinatesWanted));
}
- mDbSchemaName = mParsedConnection->mSchema;
-
return mOpen;
}
@@ -204,7 +201,7 @@
rdbi_disconnect( mContext );
mOpen = FdoConnectionState_Closed;
mGdbiConnection->Close();
- mDbSchemaName = L"";
+ mParsedConnection->mSchema = L"";
mDbiContextId = -1;
}
}
@@ -264,25 +261,29 @@
FdoStringP DbiConnection::GetUser()
{
- return (NULL == mParsedConnection) ? L"" : mParsedConnection->mUser;
+ return mParsedConnection->mUser;
}
FdoStringP DbiConnection::GetPassword()
{
- return (NULL == mParsedConnection) ? L"" : mParsedConnection->mPassword;
+ return mParsedConnection->mPassword;
}
FdoStringP DbiConnection::GetSchema()
{
- return (NULL == mParsedConnection) ? L"" : mParsedConnection->mSchema;
+ return mParsedConnection->mSchema;
}
-
FdoStringP DbiConnection::GetDataSource()
{
- return (NULL == mParsedConnection) ? L"" : mParsedConnection->mDataSource;
+ return mParsedConnection->mDataSource;
}
+FdoStringP DbiConnection::GetConnectionString()
+{
+ return mParsedConnection->mConnectionStringProperty;
+}
+
void DbiConnection::SetConnectData (FdoString *datasource, FdoString *user, FdoString *password, FdoString *schema, FdoString *connectionString, FdoString *defaultGeometryWanted)
{
if ( !mParsedConnection )
@@ -760,12 +761,12 @@
FdoStringP DbiConnection::GetDbSchemaName()
{
- return mDbSchemaName;
+ return mParsedConnection->mSchema;
}
void DbiConnection::SetDbSchemaName(const wchar_t * schemaName)
{
- mDbSchemaName = schemaName;
+ mParsedConnection->mSchema = schemaName;
}
@@ -1096,3 +1097,12 @@
return GetSchemaUtil()->GetSchemaManager();
}
+unsigned long DbiConnection::GetDbVersion()
+{
+ if (mContext == NULL)
+ return RDBI_DBVERSION_UNKNOW;
+ rdbi_vndr_info_def info;
+ rdbi_vndr_info( mContext, &info );
+
+ return info.dbversion;
+}
Modified: trunk/Providers/GenericRdbms/Src/Fdo/Connection/DbiConnection.h
===================================================================
--- trunk/Providers/GenericRdbms/Src/Fdo/Connection/DbiConnection.h 2007-02-13 00:58:47 UTC (rev 2507)
+++ trunk/Providers/GenericRdbms/Src/Fdo/Connection/DbiConnection.h 2007-02-13 18:10:57 UTC (rev 2508)
@@ -62,7 +62,8 @@
FdoStringP mConnectionStringProperty; // A connection property actually named "ConnectionString"
FdoStringP mIsGeometryFromOrdinatesWanted; // Unspecified if empty. Can be "true" or "false".
- ParseInfo (FdoString *datasource, FdoString *user, FdoString *password, FdoString *schema, FdoString *connectionString, FdoString *defaultGeometryWanted);
+ ParseInfo (FdoString *datasource = L"", FdoString *user = L"", FdoString *password = L"", FdoString *schema = L"",
+ FdoString *connectionString = L"", FdoString *defaultGeometryWanted = L"");
virtual ~ParseInfo ();
};
@@ -70,8 +71,6 @@
ParseInfo* mParsedConnection;
- FdoStringP mDbSchemaName;
-
FdoConnectionState mOpen; // if the database is open
bool mIsWorkspaceManagerEnvironment;
@@ -106,6 +105,8 @@
FdoStringP GetPassword();
FdoStringP GetSchema ();
FdoStringP GetDataSource ();
+ FdoStringP GetConnectionString ();
+ unsigned long GetDbVersion();
FDORDBMS_TEST void Close ();
//dbi_context_def *GetCtxt() { return mContext; }
Modified: trunk/Providers/GenericRdbms/Src/ODBC/Fdo/FdoRdbmsOdbcConnection.cpp
===================================================================
--- trunk/Providers/GenericRdbms/Src/ODBC/Fdo/FdoRdbmsOdbcConnection.cpp 2007-02-13 00:58:47 UTC (rev 2507)
+++ trunk/Providers/GenericRdbms/Src/ODBC/Fdo/FdoRdbmsOdbcConnection.cpp 2007-02-13 18:10:57 UTC (rev 2508)
@@ -22,8 +22,15 @@
#ifdef _WIN32
#include <tchar.h>
+#include<odbcinst.h>
+#else
+// remove #if 0 when FdoRdbmsOdbcConnection::GetSchemaNameFromDsn is active on Linux
+#if 0
+#include<odbcinst.h>
#endif
+#endif
+
#include <Inc/ut.h>
#include "FdoRdbmsOdbcConnectionInfo.h"
#include "FdoRdbmsOdbcConnection.h"
@@ -45,6 +52,7 @@
#include "FdoRdbmsOdbcSpatialManager.h"
#include "DbiConnection.h"
+#include <FdoCommonConnStringParser.h>
#include <Inc/Rdbi/proto.h>
#include "../../ODBCDriver/context.h"
@@ -174,17 +182,30 @@
FdoSchemaManagerP FdoRdbmsOdbcConnection::CreateSchemaManager()
{
- FdoStringP userName = GetDbiConnection()->GetUser();
- FdoStringP schemaName = GetSchemaNameFromDsn();
-
- if (schemaName.GetLength() > 0)
+ DbiConnection* pConn = GetDbiConnection();
+ FdoStringP userName = pConn->GetUser();
+ FdoStringP schemaName = pConn->GetDbSchemaName();
+ if (schemaName.GetLength() == 0)
{
- // If the DSN contained a schema name, take that as the only one that
- // we want to see, and which will be specified in all future requests
- // from this provider.
- // If this is not set, all schemas will be visible (occasionally more
- // useful, but also can be slow).
- GetDbiConnection()->SetDbSchemaName(schemaName);
+ FdoStringP connectionStringProperty = pConn->GetConnectionString();
+ if (connectionStringProperty.GetLength() != 0 && pConn->GetDbVersion() == RDBI_DBVERSION_ODBC_ORACLE)
+ {
+ FdoCommonConnStringParser parser (NULL, connectionStringProperty);
+ if (parser.IsConnStringValid())
+ schemaName = parser.GetPropertyValueW(L"XSM");
+ }
+ if (schemaName.GetLength() == 0)
+ schemaName = GetSchemaNameFromDsn();
+
+ if (schemaName.GetLength() > 0)
+ {
+ // If the DSN contained a schema name, take that as the only one that
+ // we want to see, and which will be specified in all future requests
+ // from this provider.
+ // If this is not set, all schemas will be visible (occasionally more
+ // useful, but also can be slow).
+ pConn->SetDbSchemaName(schemaName);
+ }
}
#if 0
@@ -197,7 +218,7 @@
{
// Set sane default for the RDBMS' schema (where things go for cases where
// we do not specify a schema in this provider).
- GetDbiConnection()->SetActiveSchema(schemaName);
+ pConn->SetActiveSchema(schemaName);
}
// Call base class' method.
@@ -419,86 +440,42 @@
}
#ifdef _WIN32
-static HKEY GetRegistryKey(HKEY topkey, const char * subkeyName)
-{
- HKEY hkey = NULL;
- TCHAR value[ODBCDR_CONNECTION_SIZE];
- DWORD size = sizeof(value) / sizeof(value[0]);;
- LONG errStatus = ERROR_SUCCESS;
- int status = FALSE;
-
- if (ERROR_SUCCESS != RegOpenKeyEx (
- topkey,
- _T(subkeyName), /* subkey name */
- 0L, /* reserved */
- KEY_QUERY_VALUE, /* security access mask */
- &hkey)) /* handle to open key */
- {
- hkey = NULL;
- }
- return hkey;
-}
-
-static FdoStringP GetRegistryValue(HKEY hkey, const char * name)
-{
- TCHAR value[ODBCDR_CONNECTION_SIZE];
- DWORD size = sizeof(value) / sizeof(value[0]);;
- LONG errStatus = ERROR_SUCCESS;
- DWORD type;
- FdoStringP valueP;
-
- errStatus = RegQueryValueEx (
- hkey, /* handle to key */
- _T(name), /* value name */
- NULL, /* reserved */
- &type, /* type buffer */
- (LPBYTE)value,/* data buffer */
- &size); /* size of data buffer */
-
- if (ERROR_SUCCESS == errStatus)
- {
- valueP = FdoStringP::Format(L"%hs", (char *) value);
- }
- return valueP;
-}
-
-#endif
-
-#define SUBKEYNAME_PREFIX "Software\\ODBC\\ODBC.INI\\"
-#define KEYNAME_DRIVER "Driver"
-#define KEYNAME_USERID_ORACLENATIVE "UserID"
-#define DRIVER_NAME_ORACLENATIVE L"SQORA32"
-
+#define ODBC_FODBC_INI L"ODBC.INI"
FdoStringP FdoRdbmsOdbcConnection::GetSchemaNameFromDsn()
{
FdoStringP schemaName;
-#ifdef _WIN32
// For Oracle on Windows, get the UserId field.
// This field is normally just a default for the username, so this use does overload
// it. However, Oracle's driver does not offer a separate "schema" field as other
// drivers do.
-
- FdoStringP dsn = GetDbiConnection()->GetDataSource();
- HKEY hkey = NULL;
- char subkeyName[ODBCDR_CONNECTION_SIZE];
- size_t subkeyNameSize = sizeof(subkeyName) / sizeof(subkeyName[0]);
- (void) _snprintf(subkeyName, subkeyNameSize-1, "%s%ls", SUBKEYNAME_PREFIX, (const wchar_t *)dsn);
-
- hkey = GetRegistryKey(HKEY_CURRENT_USER, subkeyName);
- if (NULL == hkey)
- hkey = GetRegistryKey(HKEY_LOCAL_MACHINE, subkeyName);
- if (NULL != hkey)
+ DbiConnection* pConn = GetDbiConnection();
+ FdoStringP dsn = pConn->GetDataSource();
+ wchar_t buffValue[ODBCDR_CONNECTION_SIZE];
+ if (pConn->GetDbVersion() == RDBI_DBVERSION_ODBC_ORACLE)
{
- FdoStringP driver = GetRegistryValue(hkey, KEYNAME_DRIVER);
- if (driver.Contains(DRIVER_NAME_ORACLENATIVE))
- {
- FdoStringP userId = GetRegistryValue(hkey, KEYNAME_USERID_ORACLENATIVE);
- if (userId.GetLength() > 0)
- schemaName = userId;
- }
+ if(0 != ::SQLGetPrivateProfileStringW( dsn, L"UserID", L"", buffValue, ODBCDR_CONNECTION_SIZE, ODBC_FODBC_INI ))
+ schemaName = buffValue;
}
+ return schemaName;
+}
+#else
+#define ODBC_FODBC_INI "ODBC.INI"
+FdoStringP FdoRdbmsOdbcConnection::GetSchemaNameFromDsn()
+{
+ FdoStringP schemaName;
+#if 0
+ // this code is intended for Linux but is untested.
+ // not sure if SQLGetPrivateProfileString is implemented on Linux
+ DbiConnection* pConn = GetDbiConnection();
+ FdoStringP dsn = pConn->GetDataSource();
+ char buffValue[ODBCDR_CONNECTION_SIZE];
+ if (pConn->GetDbVersion() == RDBI_DBVERSION_ODBC_ORACLE)
+ {
+ if(0 != ::SQLGetPrivateProfileString( dsn, "UserID", "", buffValue, ODBCDR_CONNECTION_SIZE, ODBC_FODBC_INI ))
+ schemaName = buffValue;
+ }
#endif
-
return schemaName;
}
+#endif
Modified: trunk/Providers/GenericRdbms/Src/UnitTest/Odbc/OdbcConnectionUtil.cpp
===================================================================
--- trunk/Providers/GenericRdbms/Src/UnitTest/Odbc/OdbcConnectionUtil.cpp 2007-02-13 00:58:47 UTC (rev 2507)
+++ trunk/Providers/GenericRdbms/Src/UnitTest/Odbc/OdbcConnectionUtil.cpp 2007-02-13 18:10:57 UTC (rev 2508)
@@ -524,7 +524,7 @@
swprintf(
connectString,
sizeof(connectString)/sizeof(wchar_t),
- L"ConnectionString=\"DRIVER={%ls};UID=%ls;PWD=%ls;DBQ=%ls;XSM=Default;\"",
+ L"ConnectionString=\"DRIVER={%ls};UID=%ls;PWD=%ls;DBQ=%ls;\"",
(FdoString*)OracleDriverName,
(FdoString*)pDatastore /*username*/,
(FdoString*)password,
@@ -643,7 +643,7 @@
swprintf(
connectString,
sizeof(connectString)/sizeof(wchar_t),
- L"ConnectionString=\"DRIVER={%ls};UID=%ls;PWD=%ls;DBQ=%ls;XSM=Default;\"",
+ L"ConnectionString=\"DRIVER={%ls};UID=%ls;PWD=%ls;DBQ=%ls;;\"",
(FdoString*)OracleDriverName,
(FdoString*)username,
(FdoString*)password,
More information about the fdo-commits
mailing list