1 /////////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     Header file wxDb class.  The wxDb class represents a connection 
   4 //              to an ODBC data source.  The wxDb class allows operations on the data 
   5 //              source such as opening and closing the data source. 
   7 // Modified by: George Tasker 
   9 //              Mark Johnson, wxWindows@mj10777.de 
  11 //                -Added support for SQL statement logging and database cataloging 
  13 //                -Added QUERY_ONLY mode support to reduce default number of cursors 
  14 //                -Added additional SQL logging code 
  15 //                -Added DEBUG-ONLY tracking of Ctable objects to detect orphaned DB connections 
  16 //                -Set ODBC option to only read committed writes to the DB so all 
  17 //                     databases operate the same in that respect 
  21 // Copyright:   (c) 1996 Remstar International, Inc. 
  22 // Licence:     wxWindows licence, plus: 
  23 // Notice:      This class library and its intellectual design are free of charge for use, 
  24 //              modification, enhancement, debugging under the following conditions: 
  25 //              1) These classes may only be used as part of the implementation of a 
  26 //                 wxWindows-based application 
  27 //              2) All enhancements and bug fixes are to be submitted back to the wxWindows 
  28 //                 user groups free of all charges for use with the wxWindows library. 
  29 //              3) These classes may not be distributed as part of any other class library, 
  30 //                 DLL, text (written or electronic), other than a complete distribution of 
  31 //                 the wxWindows GUI development toolkit. 
  33 /////////////////////////////////////////////////////////////////////////////// 
  44 // BJO 20000503: introduce new GetColumns members which are more database independant and  
  45 //               return columns in the order they were created 
  46 #define OLD_GETCOLUMNS 1 
  47 #define EXPERIMENTAL_WXDB_FUNCTIONS 1 
  49 #include "wx/version.h" 
  52     #pragma interface "db.h" 
  58 #include "wx/string.h" 
  61 // include standard Windows headers 
  62 #if defined(__WXMSW__) && !wxUSE_MFC 
  68     #include "wx/msw/winundef.h" 
  71 // If you use the wxDbCreateDataSource() function with MSW/VC6, 
  72 // you cannot use the iODBC headers, you must use the VC headers, 
  73 // plus the odbcinst.h header - gt Nov 2 2000 
  75 //  Must add "odbccp32.lib" in \wx2\wxWindows\src\makevc.env to the WINLIBS= line 
  83     #include "wx/isqlext.h" 
  89 typedef double SDOUBLE
; 
  90 typedef unsigned int UINT
; 
  93 #ifndef wxODBC_FWD_ONLY_CURSORS 
  94 #define wxODBC_FWD_ONLY_CURSORS 1 
  97 enum enumDummy 
{enumDum1
}; 
 100 #define SQL_C_BOOLEAN(datatype) (sizeof(datatype) == 1 ? SQL_C_UTINYINT : (sizeof(datatype) == 2 ? SQL_C_USHORT : SQL_C_ULONG)) 
 101 //#  define SQL_C_BOOLEAN (sizeof(int) == 2 ? SQL_C_USHORT : SQL_C_ULONG) 
 105 #define SQL_C_ENUM (sizeof(enumDummy) == 2 ? SQL_C_USHORT : SQL_C_ULONG) 
 109     #ifdef SQL_LONGVARBINARY 
 110         #define SQL_C_BLOB SQL_LONGVARBINARY 
 112         #define SQL_C_BLOB SQL_VARBINARY 
 124 const int wxDB_PATH_MAX                 
= 254; 
 126 WXDLLEXPORT_DATA(extern wxChar 
const *) SQL_LOG_FILENAME
; 
 127 WXDLLEXPORT_DATA(extern wxChar 
const *) SQL_CATALOG_FILENAME
; 
 130 const int DB_TYPE_NAME_LEN            
= 40; 
 131 const int DB_MAX_STATEMENT_LEN        
= 4096; 
 132 const int DB_MAX_WHERE_CLAUSE_LEN     
= 2048; 
 133 const int DB_MAX_ERROR_MSG_LEN        
= 512; 
 134 const int DB_MAX_ERROR_HISTORY        
= 5; 
 135 const int DB_MAX_TABLE_NAME_LEN       
= 128; 
 136 const int DB_MAX_COLUMN_NAME_LEN      
= 128; 
 138 const int DB_DATA_TYPE_VARCHAR        
= 1; 
 139 const int DB_DATA_TYPE_INTEGER        
= 2; 
 140 const int DB_DATA_TYPE_FLOAT          
= 3; 
 141 const int DB_DATA_TYPE_DATE           
= 4; 
 142 const int DB_DATA_TYPE_BLOB           
= 5; 
 144 const int DB_SELECT_KEYFIELDS         
= 1; 
 145 const int DB_SELECT_WHERE             
= 2; 
 146 const int DB_SELECT_MATCHING          
= 3; 
 147 const int DB_SELECT_STATEMENT         
= 4; 
 149 const int DB_UPD_KEYFIELDS            
= 1; 
 150 const int DB_UPD_WHERE                
= 2; 
 152 const int DB_DEL_KEYFIELDS            
= 1; 
 153 const int DB_DEL_WHERE                
= 2; 
 154 const int DB_DEL_MATCHING             
= 3; 
 156 const int DB_WHERE_KEYFIELDS          
= 1; 
 157 const int DB_WHERE_MATCHING           
= 2; 
 159 const int DB_GRANT_SELECT             
= 1; 
 160 const int DB_GRANT_INSERT             
= 2; 
 161 const int DB_GRANT_UPDATE             
= 4; 
 162 const int DB_GRANT_DELETE             
= 8; 
 163 const int DB_GRANT_ALL                
= DB_GRANT_SELECT 
| DB_GRANT_INSERT 
| DB_GRANT_UPDATE 
| DB_GRANT_DELETE
; 
 165 // ODBC Error codes (derived from ODBC SqlState codes) 
 171     DB_ERR_GENERAL_WARNING
,                            // SqlState = '01000' 
 172     DB_ERR_DISCONNECT_ERROR
,                           // SqlState = '01002' 
 173     DB_ERR_DATA_TRUNCATED
,                             // SqlState = '01004' 
 174     DB_ERR_PRIV_NOT_REVOKED
,                           // SqlState = '01006' 
 175     DB_ERR_INVALID_CONN_STR_ATTR
,                      // SqlState = '01S00' 
 176     DB_ERR_ERROR_IN_ROW
,                               // SqlState = '01S01' 
 177     DB_ERR_OPTION_VALUE_CHANGED
,                       // SqlState = '01S02' 
 178     DB_ERR_NO_ROWS_UPD_OR_DEL
,                         // SqlState = '01S03' 
 179     DB_ERR_MULTI_ROWS_UPD_OR_DEL
,                      // SqlState = '01S04' 
 180     DB_ERR_WRONG_NO_OF_PARAMS
,                         // SqlState = '07001' 
 181     DB_ERR_DATA_TYPE_ATTR_VIOL
,                        // SqlState = '07006' 
 182     DB_ERR_UNABLE_TO_CONNECT
,                          // SqlState = '08001' 
 183     DB_ERR_CONNECTION_IN_USE
,                          // SqlState = '08002' 
 184     DB_ERR_CONNECTION_NOT_OPEN
,                        // SqlState = '08003' 
 185     DB_ERR_REJECTED_CONNECTION
,                        // SqlState = '08004' 
 186     DB_ERR_CONN_FAIL_IN_TRANS
,                         // SqlState = '08007' 
 187     DB_ERR_COMM_LINK_FAILURE
,                          // SqlState = '08S01' 
 188     DB_ERR_INSERT_VALUE_LIST_MISMATCH
,                 // SqlState = '21S01' 
 189     DB_ERR_DERIVED_TABLE_MISMATCH
,                     // SqlState = '21S02' 
 190     DB_ERR_STRING_RIGHT_TRUNC
,                         // SqlState = '22001' 
 191     DB_ERR_NUMERIC_VALUE_OUT_OF_RNG
,                   // SqlState = '22003' 
 192     DB_ERR_ERROR_IN_ASSIGNMENT
,                        // SqlState = '22005' 
 193     DB_ERR_DATETIME_FLD_OVERFLOW
,                      // SqlState = '22008' 
 194     DB_ERR_DIVIDE_BY_ZERO
,                             // SqlState = '22012' 
 195     DB_ERR_STR_DATA_LENGTH_MISMATCH
,                   // SqlState = '22026' 
 196     DB_ERR_INTEGRITY_CONSTRAINT_VIOL
,                  // SqlState = '23000' 
 197     DB_ERR_INVALID_CURSOR_STATE
,                       // SqlState = '24000' 
 198     DB_ERR_INVALID_TRANS_STATE
,                        // SqlState = '25000' 
 199     DB_ERR_INVALID_AUTH_SPEC
,                          // SqlState = '28000' 
 200     DB_ERR_INVALID_CURSOR_NAME
,                        // SqlState = '34000' 
 201     DB_ERR_SYNTAX_ERROR_OR_ACCESS_VIOL
,                // SqlState = '37000' 
 202     DB_ERR_DUPLICATE_CURSOR_NAME
,                      // SqlState = '3C000' 
 203     DB_ERR_SERIALIZATION_FAILURE
,                      // SqlState = '40001' 
 204     DB_ERR_SYNTAX_ERROR_OR_ACCESS_VIOL2
,               // SqlState = '42000' 
 205     DB_ERR_OPERATION_ABORTED
,                          // SqlState = '70100' 
 206     DB_ERR_UNSUPPORTED_FUNCTION
,                       // SqlState = 'IM001' 
 207     DB_ERR_NO_DATA_SOURCE
,                             // SqlState = 'IM002' 
 208     DB_ERR_DRIVER_LOAD_ERROR
,                          // SqlState = 'IM003' 
 209     DB_ERR_SQLALLOCENV_FAILED
,                         // SqlState = 'IM004' 
 210     DB_ERR_SQLALLOCCONNECT_FAILED
,                     // SqlState = 'IM005' 
 211     DB_ERR_SQLSETCONNECTOPTION_FAILED
,                 // SqlState = 'IM006' 
 212     DB_ERR_NO_DATA_SOURCE_DLG_PROHIB
,                  // SqlState = 'IM007' 
 213     DB_ERR_DIALOG_FAILED
,                              // SqlState = 'IM008' 
 214     DB_ERR_UNABLE_TO_LOAD_TRANSLATION_DLL
,             // SqlState = 'IM009' 
 215     DB_ERR_DATA_SOURCE_NAME_TOO_LONG
,                  // SqlState = 'IM010' 
 216     DB_ERR_DRIVER_NAME_TOO_LONG
,                       // SqlState = 'IM011' 
 217     DB_ERR_DRIVER_KEYWORD_SYNTAX_ERROR
,                // SqlState = 'IM012' 
 218     DB_ERR_TRACE_FILE_ERROR
,                           // SqlState = 'IM013' 
 219     DB_ERR_TABLE_OR_VIEW_ALREADY_EXISTS
,               // SqlState = 'S0001' 
 220     DB_ERR_TABLE_NOT_FOUND
,                            // SqlState = 'S0002' 
 221     DB_ERR_INDEX_ALREADY_EXISTS
,                       // SqlState = 'S0011' 
 222     DB_ERR_INDEX_NOT_FOUND
,                            // SqlState = 'S0012' 
 223     DB_ERR_COLUMN_ALREADY_EXISTS
,                      // SqlState = 'S0021' 
 224     DB_ERR_COLUMN_NOT_FOUND
,                           // SqlState = 'S0022' 
 225     DB_ERR_NO_DEFAULT_FOR_COLUMN
,                      // SqlState = 'S0023' 
 226     DB_ERR_GENERAL_ERROR
,                              // SqlState = 'S1000' 
 227     DB_ERR_MEMORY_ALLOCATION_FAILURE
,                  // SqlState = 'S1001' 
 228     DB_ERR_INVALID_COLUMN_NUMBER
,                      // SqlState = 'S1002' 
 229     DB_ERR_PROGRAM_TYPE_OUT_OF_RANGE
,                  // SqlState = 'S1003' 
 230     DB_ERR_SQL_DATA_TYPE_OUT_OF_RANGE
,                 // SqlState = 'S1004' 
 231     DB_ERR_OPERATION_CANCELLED
,                        // SqlState = 'S1008' 
 232     DB_ERR_INVALID_ARGUMENT_VALUE
,                     // SqlState = 'S1009' 
 233     DB_ERR_FUNCTION_SEQUENCE_ERROR
,                    // SqlState = 'S1010' 
 234     DB_ERR_OPERATION_INVALID_AT_THIS_TIME
,             // SqlState = 'S1011' 
 235     DB_ERR_INVALID_TRANS_OPERATION_CODE
,               // SqlState = 'S1012' 
 236     DB_ERR_NO_CURSOR_NAME_AVAIL
,                       // SqlState = 'S1015' 
 237     DB_ERR_INVALID_STR_OR_BUF_LEN
,                     // SqlState = 'S1090' 
 238     DB_ERR_DESCRIPTOR_TYPE_OUT_OF_RANGE
,               // SqlState = 'S1091' 
 239     DB_ERR_OPTION_TYPE_OUT_OF_RANGE
,                   // SqlState = 'S1092' 
 240     DB_ERR_INVALID_PARAM_NO
,                           // SqlState = 'S1093' 
 241     DB_ERR_INVALID_SCALE_VALUE
,                        // SqlState = 'S1094' 
 242     DB_ERR_FUNCTION_TYPE_OUT_OF_RANGE
,                 // SqlState = 'S1095' 
 243     DB_ERR_INF_TYPE_OUT_OF_RANGE
,                      // SqlState = 'S1096' 
 244     DB_ERR_COLUMN_TYPE_OUT_OF_RANGE
,                   // SqlState = 'S1097' 
 245     DB_ERR_SCOPE_TYPE_OUT_OF_RANGE
,                    // SqlState = 'S1098' 
 246     DB_ERR_NULLABLE_TYPE_OUT_OF_RANGE
,                 // SqlState = 'S1099' 
 247     DB_ERR_UNIQUENESS_OPTION_TYPE_OUT_OF_RANGE
,        // SqlState = 'S1100' 
 248     DB_ERR_ACCURACY_OPTION_TYPE_OUT_OF_RANGE
,          // SqlState = 'S1101' 
 249     DB_ERR_DIRECTION_OPTION_OUT_OF_RANGE
,              // SqlState = 'S1103' 
 250     DB_ERR_INVALID_PRECISION_VALUE
,                    // SqlState = 'S1104' 
 251     DB_ERR_INVALID_PARAM_TYPE
,                         // SqlState = 'S1105' 
 252     DB_ERR_FETCH_TYPE_OUT_OF_RANGE
,                    // SqlState = 'S1106' 
 253     DB_ERR_ROW_VALUE_OUT_OF_RANGE
,                     // SqlState = 'S1107' 
 254     DB_ERR_CONCURRENCY_OPTION_OUT_OF_RANGE
,            // SqlState = 'S1108' 
 255     DB_ERR_INVALID_CURSOR_POSITION
,                    // SqlState = 'S1109' 
 256     DB_ERR_INVALID_DRIVER_COMPLETION
,                  // SqlState = 'S1110' 
 257     DB_ERR_INVALID_BOOKMARK_VALUE
,                     // SqlState = 'S1111' 
 258     DB_ERR_DRIVER_NOT_CAPABLE
,                         // SqlState = 'S1C00' 
 259     DB_ERR_TIMEOUT_EXPIRED                             
// SqlState = 'S1T00' 
 266 #ifndef SQL_MAX_AUTHSTR_LEN 
 267 // There does not seem to be a standard for this, so I am 
 268 // defaulting to the value that MS uses 
 269 #define SQL_MAX_AUTHSTR_LEN MAXNAME 
 272 class WXDLLEXPORT wxDbConnectInf
 
 275         bool freeHenvOnDestroy
; 
 279         wxChar Dsn
[SQL_MAX_DSN_LENGTH
+1];                  // Data Source Name 
 280         wxChar Uid
[SQL_MAX_USER_NAME_LEN
+1];               // User ID 
 281         wxChar AuthStr
[SQL_MAX_AUTHSTR_LEN
+1];             // Authorization string (password) 
 283         wxString Description
;                              // Not sure what the max length is 
 284         wxString FileType
;                                 // Not sure what the max length is 
 286         // Optionals needed for some databases like dBase 
 287         wxString DefaultDir
;                               // Directory that db file resides in 
 292         wxDbConnectInf(HENV henv
, const wxString 
&dsn
, const wxString 
&userID
=wxEmptyString
,  
 293                        const wxString 
&password
=wxEmptyString
, const wxString 
&defaultDir
=wxEmptyString
,  
 294                        const wxString 
&description
=wxEmptyString
, const wxString 
&fileType
=wxEmptyString
); 
 304         const HENV       
&GetHenv()          { return Henv
; }; 
 306         const wxChar    
*GetDsn()           { return Dsn
; }; 
 308         const wxChar    
*GetUid()           { return Uid
; }; 
 309         const wxChar    
*GetUserID()        { return Uid
; }; 
 311         const wxChar    
*GetAuthStr()       { return AuthStr
; }; 
 312         const wxChar    
*GetPassword()      { return AuthStr
; }; 
 314         const wxChar    
*GetDescription()   { return Description
; }; 
 315         const wxChar    
*GetFileType()      { return FileType
; }; 
 316         const wxChar    
*GetDefaultDir()    { return DefaultDir
; }; 
 318         void             SetHenv(const HENV henv
)               { Henv 
= henv
; }; 
 320         void             SetDsn(const wxString 
&dsn
); 
 322         void             SetUserID(const wxString 
&userID
); 
 323         void             SetUid(const wxString 
&uid
)            { SetUserID(uid
); }; 
 325         void             SetPassword(const wxString 
&password
); 
 326         void             SetAuthStr(const wxString 
&authstr
)    { SetPassword(authstr
); }; 
 328         void             SetDescription(const wxString 
&desc
)   { Description   
= desc
;     }; 
 329         void             SetFileType(const wxString 
&fileType
)  { FileType      
= fileType
; }; 
 330         void             SetDefaultDir(const wxString 
&defDir
)  { DefaultDir    
= defDir
;   }; 
 331 };  // class wxDbConnectInf 
 334 struct WXDLLEXPORT wxDbSqlTypeInfo
 
 340 //    short     MinimumScale; 
 345 class WXDLLEXPORT wxDbColFor
 
 348     wxString       s_Field
;              // Formated String for Output 
 349     wxString       s_Format
[7];          // Formated Objects - TIMESTAMP has the biggest (7) 
 350     wxString       s_Amount
[7];          // Formated Objects - amount of things that can be formatted 
 351     int            i_Amount
[7];          // Formated Objects - TT MM YYYY HH MM SS m 
 352     int            i_Nation
;             // 0 = timestamp , 1=EU, 2=UK, 3=International, 4=US 
 353     int            i_dbDataType
;         // conversion of the 'sqlDataType' to the generic data type used by these classes 
 360     int            Format(int Nation
, int dbDataType
, SWORD sqlDataType
, short columnSize
, short decimalDigits
); 
 364 class WXDLLEXPORT wxDbColInf
 
 367     wxChar       catalog
[128+1]; 
 368     wxChar       schema
[128+1]; 
 369     wxChar       tableName
[DB_MAX_TABLE_NAME_LEN
+1]; 
 370     wxChar       colName
[DB_MAX_COLUMN_NAME_LEN
+1]; 
 372     wxChar       typeName
[128+1]; 
 378     wxChar       remarks
[254+1]; 
 379     int          dbDataType
;  // conversion of the 'sqlDataType' to the generic data type used by these classes 
 380  // mj10777.19991224 : new 
 381     int          PkCol
;       // Primary key column       0=No; 1= First Key, 2 = Second Key etc. 
 382     wxChar       PkTableName
[DB_MAX_TABLE_NAME_LEN
+1]; // Tables that use this PKey as a FKey 
 383     int          FkCol
;       // Foreign key column       0=No; 1= First Key, 2 = Second Key etc. 
 384     wxChar       FkTableName
[DB_MAX_TABLE_NAME_LEN
+1]; // Foreign key table name 
 385     wxDbColFor  
*pColFor
;                              // How should this columns be formatted 
 394 class WXDLLEXPORT wxDbTableInf        
// Description of a Table 
 397     wxChar      tableName
[DB_MAX_TABLE_NAME_LEN
+1]; 
 398     wxChar      tableType
[254+1];           // "TABLE" or "SYSTEM TABLE" etc. 
 399     wxChar      tableRemarks
[254+1]; 
 400     UWORD       numCols
;                    // How many Columns does this Table have: GetColumnCount(..); 
 401     wxDbColInf 
*pColInf
;                    // pColInf = NULL ; User can later call GetColumns(..); 
 410 class WXDLLEXPORT wxDbInf     
// Description of a Database 
 413     wxChar        catalog
[128+1]; 
 414     wxChar        schema
[128+1]; 
 415     int           numTables
;           // How many tables does this database have 
 416     wxDbTableInf 
*pTableInf
;           // pTableInf = new wxDbTableInf[numTables]; 
 431 // These are the databases currently tested and working with these classes 
 432 // See the comments in wxDb::Dbms() for exceptions/issues with 
 433 // each of these database engines 
 438     dbmsSYBASE_ASA
,        // Adaptive Server Anywhere 
 439     dbmsSYBASE_ASE
,        // Adaptive Server Enterprise 
 453 // The wxDb::errorList is copied to this variable when the wxDb object 
 454 // is closed.  This way, the error list is still available after the 
 455 // database object is closed.  This is necessary if the database 
 456 // connection fails so the calling application can show the operator 
 457 // why the connection failed.  Note: as each wxDb object is closed, it 
 458 // will overwrite the errors of the previously destroyed wxDb object in 
 461 WXDLLEXPORT_DATA(extern wxChar
) DBerrorList
[DB_MAX_ERROR_HISTORY
][DB_MAX_ERROR_MSG_LEN
]; 
 464 class WXDLLEXPORT wxDb
 
 468     bool             dbIsCached
;      // Was connection created by caching functions 
 469     wxString         dsn
;             // Data source name 
 470     wxString         uid
;             // User ID 
 471     wxString         authStr
;         // Authorization string (password) 
 472     FILE            *fpSqlLog
;        // Sql Log file pointer 
 473     wxDbSqlLogState  sqlLogState
;     // On or Off 
 475     wxDBMS           dbmsType
;        // Type of datasource - i.e. Oracle, dBase, SQLServer, etc 
 477     // Private member functions 
 478     bool             getDbInfo(void); 
 479     bool             getDataTypeInfo(SWORD fSqlType
, wxDbSqlTypeInfo 
&structSQLTypeInfo
); 
 480     bool             setConnectionOptions(void); 
 481     void             logError(const wxString 
&errMsg
, const wxString 
&SQLState
); 
 482     const wxChar    
*convertUserID(const wxChar 
*userID
, wxString 
&UserID
); 
 485 #if !wxODBC_BACKWARD_COMPATABILITY 
 487     HENV  henv
;        // ODBC Environment handle 
 488     HDBC  hdbc
;        // ODBC DB Connection handle 
 489     HSTMT hstmt
;       // ODBC Statement handle 
 491     //Error reporting mode 
 494     // Number of Ctable objects connected to this db object.  FOR INTERNAL USE ONLY!!! 
 495     unsigned int nTables
; 
 497     // Information about logical data types VARCHAR, INTEGER, FLOAT and DATE. 
 499     // This information is obtained from the ODBC driver by use of the 
 500     // SQLGetTypeInfo() function.  The key piece of information is the 
 501     // type name the data source uses for each logical data type. 
 502     // e.g. VARCHAR; Oracle calls it VARCHAR2. 
 503     wxDbSqlTypeInfo typeInfVarchar
; 
 504     wxDbSqlTypeInfo typeInfInteger
; 
 505     wxDbSqlTypeInfo typeInfFloat
; 
 506     wxDbSqlTypeInfo typeInfDate
; 
 507     wxDbSqlTypeInfo typeInfBlob
; 
 512     void             setCached(bool cached
)  { dbIsCached 
= cached
; };  // This function must only be called by wxDbGetConnection() and wxDbCloseConnections!!! 
 513     bool             IsCached() { return dbIsCached
; }; 
 515     bool             GetDataTypeInfo(SWORD fSqlType
, wxDbSqlTypeInfo 
&structSQLTypeInfo
) 
 516                             { return getDataTypeInfo(fSqlType
, structSQLTypeInfo
); } 
 518 #if wxODBC_BACKWARD_COMPATABILITY 
 520     HENV  henv
;        // ODBC Environment handle 
 521     HDBC  hdbc
;        // ODBC DB Connection handle 
 522     HSTMT hstmt
;       // ODBC Statement handle 
 524     //Error reporting mode 
 527     // Number of Ctable objects connected to this db object.  FOR INTERNAL USE ONLY!!! 
 528     unsigned int nTables
; 
 531     // The following structure contains database information gathered from the 
 532     // datasource when the datasource is first opened. 
 535         wxChar dbmsName
[40];                             // Name of the dbms product 
 536         wxChar dbmsVer
[64];                              // Version # of the dbms product 
 537         wxChar driverName
[40];                           // Driver name 
 538         wxChar odbcVer
[60];                              // ODBC version of the driver 
 539         wxChar drvMgrOdbcVer
[60];                        // ODBC version of the driver manager 
 540         wxChar driverVer
[60];                            // Driver version 
 541         wxChar serverName
[80];                           // Server Name, typically a connect string 
 542         wxChar databaseName
[128];                        // Database filename 
 543         wxChar outerJoins
[2];                            // Indicates whether the data source supports outer joins 
 544         wxChar procedureSupport
[2];                      // Indicates whether the data source supports stored procedures 
 545         wxChar accessibleTables
[2];                      // Indicates whether the data source only reports accessible tables in SQLTables. 
 546         UWORD  maxConnections
;                           // Maximum # of connections the data source supports 
 547         UWORD  maxStmts
;                                 // Maximum # of HSTMTs per HDBC 
 548         UWORD  apiConfLvl
;                               // ODBC API conformance level 
 549         UWORD  cliConfLvl
;                               // Indicates whether the data source is SAG compliant 
 550         UWORD  sqlConfLvl
;                               // SQL conformance level 
 551         UWORD  cursorCommitBehavior
;                     // Indicates how cursors are affected by a db commit 
 552         UWORD  cursorRollbackBehavior
;                   // Indicates how cursors are affected by a db rollback 
 553         UWORD  supportNotNullClause
;                     // Indicates if data source supports NOT NULL clause 
 554         wxChar supportIEF
[2];                            // Integrity Enhancement Facility (Referential Integrity) 
 555         UDWORD txnIsolation
;                             // Default transaction isolation level supported by the driver 
 556         UDWORD txnIsolationOptions
;                      // Transaction isolation level options available 
 557         UDWORD fetchDirections
;                          // Fetch directions supported 
 558         UDWORD lockTypes
;                                // Lock types supported in SQLSetPos 
 559         UDWORD posOperations
;                            // Position operations supported in SQLSetPos 
 560         UDWORD posStmts
;                                 // Position statements supported 
 561         UDWORD scrollConcurrency
;                        // Concurrency control options supported for scrollable cursors 
 562         UDWORD scrollOptions
;                            // Scroll Options supported for scrollable cursors 
 563         UDWORD staticSensitivity
;                        // Indicates if additions, deletions and updates can be detected 
 564         UWORD  txnCapable
;                               // Indicates if the data source supports transactions 
 565         UDWORD loginTimeout
;                             // Number seconds to wait for a login request 
 571     wxChar errorList
[DB_MAX_ERROR_HISTORY
][DB_MAX_ERROR_MSG_LEN
]; 
 572     wxChar errorMsg
[SQL_MAX_MESSAGE_LENGTH
]; 
 576 #if wxODBC_BACKWARD_COMPATABILITY 
 577     // Information about logical data types VARCHAR, INTEGER, FLOAT and DATE. 
 579     // This information is obtained from the ODBC driver by use of the 
 580     // SQLGetTypeInfo() function.  The key piece of information is the 
 581     // type name the data source uses for each logical data type. 
 582     // e.g. VARCHAR; Oracle calls it VARCHAR2. 
 583     wxDbSqlTypeInfo typeInfVarchar
; 
 584     wxDbSqlTypeInfo typeInfInteger
; 
 585     wxDbSqlTypeInfo typeInfFloat
; 
 586     wxDbSqlTypeInfo typeInfDate
; 
 587     wxDbSqlTypeInfo typeInfBlob
; 
 590     // Public member functions 
 591     wxDb(const HENV 
&aHenv
, bool FwdOnlyCursors
=(bool)wxODBC_FWD_ONLY_CURSORS
); 
 594     bool         Open(const wxString 
&Dsn
, const wxString 
&Uid
, const wxString 
&AuthStr
);  // Data Source Name, User ID, Password 
 595     bool         Open(wxDbConnectInf 
*dbConnectInf
); 
 596     bool         Open(wxDb 
*copyDb
);  // pointer to a wxDb whose connection info should be copied rather than re-queried 
 598     bool         CommitTrans(void); 
 599     bool         RollbackTrans(void); 
 600     bool         DispAllErrors(HENV aHenv
, HDBC aHdbc 
= SQL_NULL_HDBC
, HSTMT aHstmt 
= SQL_NULL_HSTMT
); 
 601     bool         GetNextError(HENV aHenv
, HDBC aHdbc 
= SQL_NULL_HDBC
, HSTMT aHstmt 
= SQL_NULL_HSTMT
); 
 602     void         DispNextError(void); 
 603     bool         CreateView(const wxString 
&viewName
, const wxString 
&colList
, const wxString 
&pSqlStmt
, bool attemptDrop
=TRUE
); 
 604     bool         DropView(const wxString 
&viewName
); 
 605     bool         ExecSql(const wxString 
&pSqlStmt
); 
 607     bool         GetData(UWORD colNo
, SWORD cType
, PTR pData
, SDWORD maxLen
, SDWORD FAR 
*cbReturned
); 
 608     bool         Grant(int privileges
, const wxString 
&tableName
, const wxString 
&userList 
= wxT("PUBLIC")); 
 609     int          TranslateSqlState(const wxString 
&SQLState
); 
 610     wxDbInf     
*GetCatalog(const wxChar 
*userID
=NULL
); 
 611     bool         Catalog(const wxChar 
*userID
=NULL
, const wxString 
&fileName
=SQL_CATALOG_FILENAME
); 
 612     int          GetKeyFields(const wxString 
&tableName
, wxDbColInf
* colInf
, UWORD noCols
); 
 614     wxDbColInf  
*GetColumns(wxChar 
*tableName
[], const wxChar 
*userID
=NULL
); 
 615     wxDbColInf  
*GetColumns(const wxString 
&tableName
, UWORD 
*numCols
, const wxChar 
*userID
=NULL
);  
 617     int             GetColumnCount(const wxString 
&tableName
, const wxChar 
*userID
=NULL
); 
 618     const wxChar   
*GetDatabaseName(void)  {return dbInf
.dbmsName
;} 
 619     const wxString 
&GetDataSource(void)    {return dsn
;} 
 620     const wxString 
&GetDatasourceName(void){return dsn
;} 
 621     const wxString 
&GetUsername(void)      {return uid
;} 
 622     const wxString 
&GetPassword(void)      {return authStr
;} 
 623     bool            IsOpen(void)           {return dbIsOpen
;} 
 624     HENV            
GetHENV(void)          {return henv
;} 
 625     HDBC            
GetHDBC(void)          {return hdbc
;} 
 626     HSTMT           
GetHSTMT(void)         {return hstmt
;} 
 627     int             GetTableCount()        {return nTables
;}  // number of tables using this connection 
 628     wxDbSqlTypeInfo 
GetTypeInfVarchar()    {return typeInfVarchar
;} 
 629     wxDbSqlTypeInfo 
GetTypeInfInteger()    {return typeInfInteger
;} 
 630     wxDbSqlTypeInfo 
GetTypeInfFloat()      {return typeInfFloat
;} 
 631     wxDbSqlTypeInfo 
GetTypeInfDate()       {return typeInfDate
;} 
 632     wxDbSqlTypeInfo 
GetTypeInfBlob()       {return typeInfBlob
;} 
 634     // tableName can refer to a table, view, alias or synonym 
 635     bool         TableExists(const wxString 
&tableName
, const wxChar 
*userID
=NULL
,  
 636                              const wxString 
&tablePath
=wxEmptyString
); 
 637     bool         TablePrivileges(const wxString 
&tableName
, const wxString 
&priv
,  
 638                                  const wxChar 
*userID
=NULL
, const wxChar 
*schema
=NULL
,  
 639                                  const wxString 
&path
=wxEmptyString
); 
 641     // These two functions return the table name or column name in a form ready 
 642     // for use in SQL statements.  For example, if the datasource allows spaces 
 643     // in the table name or column name, the returned string will have the 
 644     // correct enclosing marks around the name to allow it to be properly  
 645     // included in a SQL statement 
 646     const wxString  
SQLTableName(const wxChar 
*tableName
); 
 647     const wxString  
SQLColumnName(const wxChar 
*colName
); 
 649     void         LogError(const wxString 
&errMsg
, const wxString 
&SQLState 
= wxEmptyString
)  
 650                         { logError(errMsg
, SQLState
); } 
 651     void         SetDebugErrorMessages(bool state
) { silent 
= !state
; } 
 652     bool         SetSqlLogging(wxDbSqlLogState state
, const wxString 
&filename 
= SQL_LOG_FILENAME
,  
 653                                bool append 
= FALSE
); 
 654     bool         WriteSqlLog(const wxString 
&logMsg
); 
 657     bool         ModifyColumn(const wxString 
&tableName
, const wxString 
&columnName
, 
 658                               int dataType
, ULONG columnLength
=0, 
 659                               const wxString 
&optionalParam
=wxEmptyString
); 
 661     bool         FwdOnlyCursors(void)  {return fwdOnlyCursors
;} 
 663     // These two functions are provided strictly for use by wxDbTable. 
 664     // DO NOT USE THESE FUNCTIONS, OR MEMORY LEAKS MAY OCCUR 
 665     void         incrementTableCount() { nTables
++; return; } 
 666     void         decrementTableCount() { nTables
--; return; } 
 671 // This structure forms a node in a linked list.  The linked list of "DbList" objects 
 672 // keeps track of allocated database connections.  This allows the application to 
 673 // open more than one database connection through ODBC for multiple transaction support 
 674 // or for multiple database support. 
 677     wxDbList 
*PtrPrev
;       // Pointer to previous item in the list 
 678     wxString  Dsn
;           // Data Source Name 
 679     wxString  Uid
;           // User ID 
 680     wxString  AuthStr
;       // Authorization string (password) 
 681     wxDb     
*PtrDb
;         // Pointer to the wxDb object 
 682     bool      Free
;          // Is item free or in use? 
 683     wxDbList 
*PtrNext
;       // Pointer to next item in the list 
 688 #include "wx/object.h" 
 689 class wxTablesInUse 
: public wxObject
 
 692         const wxChar  
*tableName
; 
 699 // The following routines allow a user to get new database connections, free them 
 700 // for other code segments to use, or close all of them when the application has 
 702 wxDb  WXDLLEXPORT 
*wxDbGetConnection(wxDbConnectInf 
*pDbConfig
, bool FwdOnlyCursors
=(bool)wxODBC_FWD_ONLY_CURSORS
); 
 703 bool  WXDLLEXPORT  
wxDbFreeConnection(wxDb 
*pDb
); 
 704 void  WXDLLEXPORT  
wxDbCloseConnections(void); 
 705 int   WXDLLEXPORT  
wxDbConnectionsInUse(void); 
 708 // Writes a message to the wxLog window (stdout usually) when an internal error 
 709 // situation occurs.  This function only works in DEBUG builds 
 710 const wxChar WXDLLEXPORT 
*wxDbLogExtendedErrorMsg(const wxChar 
*userText
, 
 712                                                   const wxChar 
*ErrFile
, 
 716 // This function sets the sql log state for all open wxDb objects 
 717 bool  WXDLLEXPORT  
wxDbSqlLog(wxDbSqlLogState state
, const wxString 
&filename 
= SQL_LOG_FILENAME
); 
 721 // MSW/VC6 ONLY!!!  Experimental 
 722 int WXDLLEXPORT 
wxDbCreateDataSource(const wxString 
&driverName
, const wxString 
&dsn
, const wxString 
&description
=wxEmptyString
, 
 723                                      bool sysDSN
=FALSE
, const wxString 
&defDir
=wxEmptyString
, wxWindow 
*parent
=NULL
); 
 726 // This routine allows you to query a driver manager 
 727 // for a list of available datasources.  Call this routine 
 728 // the first time using SQL_FETCH_FIRST.  Continue to call it 
 729 // using SQL_FETCH_NEXT until you've exhausted the list. 
 730 bool WXDLLEXPORT 
wxDbGetDataSource(HENV henv
, wxChar 
*Dsn
, SWORD DsnMax
, wxChar 
*DsDesc
, 
 731                                    SWORD DsDescMax
, UWORD direction 
= SQL_FETCH_NEXT
); 
 734 // Change this to 0 to remove use of all deprecated functions 
 735 #if wxODBC_BACKWARD_COMPATABILITY 
 736 //################################################################################# 
 737 //############### DEPRECATED functions for backward compatability ################# 
 738 //################################################################################# 
 740 // Backward compability structures/classes.  This will eventually go away 
 741 const int DB_PATH_MAX      
= wxDB_PATH_MAX
; 
 744 typedef wxDbTableInf         wxTableInf
; 
 745 typedef wxDbColInf           wxColInf
; 
 746 typedef wxDbColInf           CcolInf
; 
 747 typedef wxDbColFor           wxColFor
; 
 748 typedef wxDbSqlTypeInfo      SqlTypeInfo
; 
 749 typedef wxDbSqlTypeInfo      wxSqlTypeInfo
; 
 750 typedef enum wxDbSqlLogState sqlLog
; 
 751 typedef enum wxDbSqlLogState wxSqlLogState
; 
 752 typedef enum wxDBMS          dbms
; 
 753 typedef enum wxDBMS          DBMS
; 
 754 typedef wxODBC_ERRORS        ODBC_ERRORS
; 
 755 typedef wxDbConnectInf       DbStuff
; 
 756 typedef wxDbList             DbList
; 
 758 typedef wxTablesInUse        CstructTablesInUse
; 
 761 // Deprecated function names that are replaced by the function names listed above 
 762 wxDB  WXDLLEXPORT 
*GetDbConnection(DbStuff 
*pDbStuff
, bool FwdOnlyCursors
=(bool)wxODBC_FWD_ONLY_CURSORS
); 
 763 bool  WXDLLEXPORT  
FreeDbConnection(wxDB 
*pDb
); 
 764 void  WXDLLEXPORT  
CloseDbConnections(void); 
 765 int   WXDLLEXPORT  
NumberDbConnectionsInUse(void); 
 767 bool SqlLog(sqlLog state
, const char *filename 
= SQL_LOG_FILENAME
); 
 769 bool WXDLLEXPORT 
GetDataSource(HENV henv
, char *Dsn
, SWORD DsnMax
, char *DsDesc
, SWORD DsDescMax
, 
 770                                UWORD direction 
= SQL_FETCH_NEXT
); 
 771 #endif  // Deprecated structures/classes/functions