2013-02-07 10:34:27 +01:00
|
|
|
/*************** Tabodbc H Declares Source Code File (.H) **************/
|
2015-01-13 17:24:31 +01:00
|
|
|
/* Name: TABODBC.H Version 1.8 */
|
2013-02-07 10:34:27 +01:00
|
|
|
/* */
|
2015-01-13 17:24:31 +01:00
|
|
|
/* (C) Copyright to the author Olivier BERTRAND 2000-2015 */
|
2013-02-07 10:34:27 +01:00
|
|
|
/* */
|
|
|
|
/* This file contains the TDBODBC classes declares. */
|
|
|
|
/***********************************************************************/
|
|
|
|
#include "colblk.h"
|
2013-02-08 03:27:12 +01:00
|
|
|
#include "resource.h"
|
2013-02-07 10:34:27 +01:00
|
|
|
|
|
|
|
typedef class ODBCDEF *PODEF;
|
|
|
|
typedef class TDBODBC *PTDBODBC;
|
|
|
|
typedef class ODBCCOL *PODBCCOL;
|
2013-10-11 13:57:56 +02:00
|
|
|
typedef class TDBXDBC *PTDBXDBC;
|
|
|
|
typedef class XSRCCOL *PXSRCCOL;
|
2013-02-07 10:34:27 +01:00
|
|
|
typedef class TDBOIF *PTDBOIF;
|
|
|
|
typedef class OIFCOL *POIFCOL;
|
2013-02-08 03:27:12 +01:00
|
|
|
typedef class TDBSRC *PTDBSRC;
|
2013-02-07 10:34:27 +01:00
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* ODBC table. */
|
|
|
|
/***********************************************************************/
|
2017-02-16 18:01:48 +01:00
|
|
|
class DllExport ODBCDEF : public EXTDEF { /* Logical table description */
|
2013-10-11 13:57:56 +02:00
|
|
|
friend class TDBODBC;
|
|
|
|
friend class TDBXDBC;
|
2013-12-16 01:32:47 +01:00
|
|
|
friend class TDBDRV;
|
2015-01-13 17:24:31 +01:00
|
|
|
friend class TDBOTB;
|
2016-07-14 20:12:22 +02:00
|
|
|
friend class TDBOCL;
|
|
|
|
public:
|
2013-02-07 10:34:27 +01:00
|
|
|
// Constructor
|
|
|
|
ODBCDEF(void);
|
|
|
|
|
|
|
|
// Implementation
|
|
|
|
virtual const char *GetType(void) {return "ODBC";}
|
|
|
|
PSZ GetConnect(void) {return Connect;}
|
2017-02-16 18:01:48 +01:00
|
|
|
//PSZ GetTabname(void) {return Tabname;}
|
|
|
|
//PSZ GetTabschema(void) {return Tabschema;}
|
|
|
|
//PSZ GetTabcat(void) {return Tabcat;}
|
|
|
|
//PSZ GetSrcdef(void) {return Srcdef;}
|
|
|
|
//char GetSep(void) {return (Sep) ? *Sep : 0;}
|
|
|
|
//int GetQuoted(void) {return Quoted;}
|
2013-02-07 10:34:27 +01:00
|
|
|
int GetCatver(void) {return Catver;}
|
2017-02-16 18:01:48 +01:00
|
|
|
//int GetOptions(void) {return Options;}
|
2013-02-07 10:34:27 +01:00
|
|
|
|
|
|
|
// Methods
|
2015-12-04 22:38:16 +01:00
|
|
|
virtual int Indexable(void) {return 2;}
|
|
|
|
virtual bool DefineAM(PGLOBAL g, LPCSTR am, int poff);
|
2013-02-07 10:34:27 +01:00
|
|
|
virtual PTDB GetTable(PGLOBAL g, MODE m);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
// Members
|
|
|
|
PSZ Connect; /* ODBC connection string */
|
2017-02-16 18:01:48 +01:00
|
|
|
//PSZ Tabname; /* External table name */
|
|
|
|
//PSZ Tabschema; /* External table schema */
|
|
|
|
//PSZ Username; /* User connect name */
|
|
|
|
//PSZ Password; /* Password connect info */
|
|
|
|
//PSZ Tabcat; /* External table catalog */
|
|
|
|
//PSZ Tabtyp; /* Catalog table type */
|
|
|
|
//PSZ Colpat; /* Catalog column pattern */
|
|
|
|
//PSZ Srcdef; /* The source table SQL definition */
|
|
|
|
//PSZ Qchar; /* Identifier quoting character */
|
|
|
|
//PSZ Qrystr; /* The original query */
|
|
|
|
//PSZ Sep; /* Decimal separator */
|
2013-02-07 10:34:27 +01:00
|
|
|
int Catver; /* ODBC version for catalog functions */
|
2017-02-16 18:01:48 +01:00
|
|
|
//int Options; /* Open connection options */
|
|
|
|
//int Cto; /* Open connection timeout */
|
|
|
|
//int Qto; /* Query (command) timeout */
|
|
|
|
//int Quoted; /* Identifier quoting level */
|
|
|
|
//int Maxerr; /* Maxerr for an Exec table */
|
|
|
|
//int Maxres; /* Maxres for a catalog table */
|
|
|
|
//int Memory; /* Put result set in memory */
|
|
|
|
//bool Scrollable; /* Use scrollable cursor */
|
|
|
|
//bool Xsrc; /* Execution type */
|
2015-01-31 15:05:43 +01:00
|
|
|
bool UseCnc; /* Use SQLConnect (!SQLDriverConnect) */
|
2013-02-07 10:34:27 +01:00
|
|
|
}; // end of ODBCDEF
|
|
|
|
|
|
|
|
#if !defined(NODBC)
|
|
|
|
#include "odbconn.h"
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* This is the ODBC Access Method class declaration for files from */
|
|
|
|
/* other DB drivers to be accessed via ODBC. */
|
|
|
|
/***********************************************************************/
|
2017-02-16 18:01:48 +01:00
|
|
|
class TDBODBC : public TDBEXT {
|
2013-02-07 10:34:27 +01:00
|
|
|
friend class ODBCCOL;
|
|
|
|
friend class ODBConn;
|
|
|
|
public:
|
|
|
|
// Constructor
|
|
|
|
TDBODBC(PODEF tdp = NULL);
|
|
|
|
TDBODBC(PTDBODBC tdbp);
|
|
|
|
|
|
|
|
// Implementation
|
|
|
|
virtual AMT GetAmType(void) {return TYPE_AM_ODBC;}
|
|
|
|
virtual PTDB Duplicate(PGLOBAL g)
|
|
|
|
{return (PTDB)new(g) TDBODBC(this);}
|
|
|
|
|
|
|
|
// Methods
|
2017-02-16 18:01:48 +01:00
|
|
|
virtual PTDB Clone(PTABS t);
|
|
|
|
//virtual int GetRecpos(void);
|
2015-02-28 23:01:55 +01:00
|
|
|
virtual bool SetRecpos(PGLOBAL g, int recpos);
|
2013-08-09 18:02:47 +02:00
|
|
|
virtual PSZ GetFile(PGLOBAL g);
|
2013-02-07 10:34:27 +01:00
|
|
|
virtual void SetFile(PGLOBAL g, PSZ fn);
|
|
|
|
virtual void ResetSize(void);
|
2014-08-07 17:59:21 +02:00
|
|
|
//virtual int GetAffectedRows(void) {return AftRows;}
|
2013-08-09 18:02:47 +02:00
|
|
|
virtual PSZ GetServer(void) {return "ODBC";}
|
2014-04-19 17:02:53 +02:00
|
|
|
virtual int Indexable(void) {return 2;}
|
2013-02-07 10:34:27 +01:00
|
|
|
|
|
|
|
// Database routines
|
|
|
|
virtual PCOL MakeCol(PGLOBAL g, PCOLDEF cdp, PCOL cprec, int n);
|
2014-07-17 18:13:51 +02:00
|
|
|
virtual int Cardinality(PGLOBAL g);
|
2017-02-16 18:01:48 +01:00
|
|
|
//virtual int GetMaxSize(PGLOBAL g);
|
|
|
|
//virtual int GetProgMax(PGLOBAL g);
|
2013-02-07 10:34:27 +01:00
|
|
|
virtual bool OpenDB(PGLOBAL g);
|
|
|
|
virtual int ReadDB(PGLOBAL g);
|
|
|
|
virtual int WriteDB(PGLOBAL g);
|
|
|
|
virtual int DeleteDB(PGLOBAL g, int irc);
|
|
|
|
virtual void CloseDB(PGLOBAL g);
|
2015-12-04 22:38:16 +01:00
|
|
|
virtual bool ReadKey(PGLOBAL g, OPVAL op, const key_range *kr);
|
2013-02-07 10:34:27 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// Internal functions
|
2017-02-16 18:01:48 +01:00
|
|
|
//int Decode(char *utf, char *buf, size_t n);
|
|
|
|
//bool MakeSQL(PGLOBAL g, bool cnt);
|
2015-12-04 22:38:16 +01:00
|
|
|
bool MakeInsert(PGLOBAL g);
|
2017-02-16 18:01:48 +01:00
|
|
|
//virtual bool MakeCommand(PGLOBAL g);
|
2013-02-07 10:34:27 +01:00
|
|
|
//bool MakeFilter(PGLOBAL g, bool c);
|
2013-10-11 13:57:56 +02:00
|
|
|
bool BindParameters(PGLOBAL g);
|
2013-11-13 00:15:38 +01:00
|
|
|
//char *MakeUpdate(PGLOBAL g);
|
|
|
|
//char *MakeDelete(PGLOBAL g);
|
2013-02-07 10:34:27 +01:00
|
|
|
|
|
|
|
// Members
|
|
|
|
ODBConn *Ocp; // Points to an ODBC connection class
|
2013-02-08 03:27:12 +01:00
|
|
|
ODBCCOL *Cnp; // Points to count(*) column
|
2015-01-31 15:05:43 +01:00
|
|
|
ODBCPARM Ops; // Additional parameters
|
2015-12-04 22:38:16 +01:00
|
|
|
char *Connect; // Points to connection string
|
2013-02-07 10:34:27 +01:00
|
|
|
int Catver; // Catalog ODBC version
|
2015-01-31 15:05:43 +01:00
|
|
|
bool UseCnc; // Use SQLConnect (!SQLDriverConnect)
|
2013-02-07 10:34:27 +01:00
|
|
|
}; // end of class TDBODBC
|
|
|
|
|
|
|
|
/***********************************************************************/
|
2013-10-11 13:57:56 +02:00
|
|
|
/* Class ODBCCOL: ODBC access method column descriptor. */
|
2013-02-07 10:34:27 +01:00
|
|
|
/* This A.M. is used for ODBC tables. */
|
|
|
|
/***********************************************************************/
|
2017-02-16 18:01:48 +01:00
|
|
|
class ODBCCOL : public EXTCOL {
|
2013-02-07 10:34:27 +01:00
|
|
|
friend class TDBODBC;
|
|
|
|
public:
|
|
|
|
// Constructors
|
|
|
|
ODBCCOL(PCOLDEF cdp, PTDB tdbp, PCOL cprec, int i, PSZ am = "ODBC");
|
|
|
|
ODBCCOL(ODBCCOL *colp, PTDB tdbp); // Constructor used in copy process
|
|
|
|
|
|
|
|
// Implementation
|
|
|
|
virtual int GetAmType(void) {return TYPE_AM_ODBC;}
|
|
|
|
SQLLEN *GetStrLen(void) {return StrLen;}
|
2017-02-16 18:01:48 +01:00
|
|
|
// int GetRank(void) {return Rank;}
|
2013-02-07 10:34:27 +01:00
|
|
|
// PVBLK GetBlkp(void) {return Blkp;}
|
2017-02-16 18:01:48 +01:00
|
|
|
// void SetCrp(PCOLRES crp) {Crp = crp;}
|
2013-02-07 10:34:27 +01:00
|
|
|
|
|
|
|
// Methods
|
2017-02-16 18:01:48 +01:00
|
|
|
//virtual bool SetBuffer(PGLOBAL g, PVAL value, bool ok, bool check);
|
2013-02-07 10:34:27 +01:00
|
|
|
virtual void ReadColumn(PGLOBAL g);
|
|
|
|
virtual void WriteColumn(PGLOBAL g);
|
|
|
|
void AllocateBuffers(PGLOBAL g, int rows);
|
|
|
|
void *GetBuffer(DWORD rows);
|
|
|
|
SWORD GetBuflen(void);
|
|
|
|
// void Print(PGLOBAL g, FILE *, uint);
|
|
|
|
|
|
|
|
protected:
|
2017-02-16 18:01:48 +01:00
|
|
|
// Constructor for count(*) column
|
2013-02-07 10:34:27 +01:00
|
|
|
ODBCCOL(void);
|
|
|
|
|
|
|
|
// Members
|
2013-10-11 13:57:56 +02:00
|
|
|
TIMESTAMP_STRUCT *Sqlbuf; // To get SQL_TIMESTAMP's
|
2017-02-16 18:01:48 +01:00
|
|
|
//PCOLRES Crp; // To storage result
|
|
|
|
//void *Bufp; // To extended buffer
|
|
|
|
//PVBLK Blkp; // To Value Block
|
2013-02-07 10:34:27 +01:00
|
|
|
//char F_Date[12]; // Internal Date format
|
2017-02-16 18:01:48 +01:00
|
|
|
//PVAL To_Val; // To value used for Insert
|
2013-02-07 10:34:27 +01:00
|
|
|
SQLLEN *StrLen; // As returned by ODBC
|
2013-10-11 13:57:56 +02:00
|
|
|
SQLLEN Slen; // Used with Fetch
|
2017-02-16 18:01:48 +01:00
|
|
|
//int Rank; // Rank (position) number in the query
|
2013-02-07 10:34:27 +01:00
|
|
|
}; // end of class ODBCCOL
|
|
|
|
|
2013-10-11 13:57:56 +02:00
|
|
|
/***********************************************************************/
|
|
|
|
/* This is the ODBC Access Method class declaration that send */
|
|
|
|
/* commands to be executed by other DB ODBC drivers. */
|
|
|
|
/***********************************************************************/
|
|
|
|
class TDBXDBC : public TDBODBC {
|
|
|
|
friend class XSRCCOL;
|
|
|
|
friend class ODBConn;
|
|
|
|
public:
|
2013-11-06 18:22:09 +01:00
|
|
|
// Constructors
|
|
|
|
TDBXDBC(PODEF tdp = NULL);
|
|
|
|
TDBXDBC(PTDBXDBC tdbp);
|
2013-10-11 13:57:56 +02:00
|
|
|
|
|
|
|
// Implementation
|
2013-11-06 18:22:09 +01:00
|
|
|
virtual AMT GetAmType(void) {return TYPE_AM_XDBC;}
|
2013-10-11 13:57:56 +02:00
|
|
|
virtual PTDB Duplicate(PGLOBAL g)
|
|
|
|
{return (PTDB)new(g) TDBXDBC(this);}
|
|
|
|
|
|
|
|
// Methods
|
2017-02-16 18:01:48 +01:00
|
|
|
virtual PTDB Clone(PTABS t);
|
2013-10-11 13:57:56 +02:00
|
|
|
|
|
|
|
// Database routines
|
|
|
|
virtual PCOL MakeCol(PGLOBAL g, PCOLDEF cdp, PCOL cprec, int n);
|
|
|
|
virtual int GetMaxSize(PGLOBAL g);
|
|
|
|
virtual bool OpenDB(PGLOBAL g);
|
|
|
|
virtual int ReadDB(PGLOBAL g);
|
|
|
|
virtual int WriteDB(PGLOBAL g);
|
2013-11-11 13:00:39 +01:00
|
|
|
virtual int DeleteDB(PGLOBAL g, int irc);
|
2013-10-11 13:57:56 +02:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// Internal functions
|
2013-11-06 18:22:09 +01:00
|
|
|
PCMD MakeCMD(PGLOBAL g);
|
2013-10-11 13:57:56 +02:00
|
|
|
|
|
|
|
// Members
|
2013-11-06 18:22:09 +01:00
|
|
|
PCMD Cmdlist; // The commands to execute
|
2013-10-11 13:57:56 +02:00
|
|
|
char *Cmdcol; // The name of the Xsrc command column
|
2013-11-06 18:22:09 +01:00
|
|
|
int Mxr; // Maximum errors before closing
|
|
|
|
int Nerr; // Number of errors so far
|
2013-10-11 13:57:56 +02:00
|
|
|
}; // end of class TDBXDBC
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* Used by table in source execute mode. */
|
|
|
|
/***********************************************************************/
|
|
|
|
class XSRCCOL : public ODBCCOL {
|
|
|
|
friend class TDBXDBC;
|
|
|
|
public:
|
|
|
|
// Constructors
|
|
|
|
XSRCCOL(PCOLDEF cdp, PTDB tdbp, PCOL cprec, int i, PSZ am = "ODBC");
|
|
|
|
XSRCCOL(XSRCCOL *colp, PTDB tdbp); // Constructor used in copy process
|
|
|
|
|
|
|
|
// Implementation
|
|
|
|
//virtual int GetAmType(void) {return TYPE_AM_ODBC;}
|
|
|
|
|
|
|
|
// Methods
|
|
|
|
virtual void ReadColumn(PGLOBAL g);
|
|
|
|
virtual void WriteColumn(PGLOBAL g);
|
|
|
|
// void Print(PGLOBAL g, FILE *, uint);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
// Members
|
|
|
|
char *Buffer; // To get returned message
|
|
|
|
int Flag; // Column content desc
|
|
|
|
}; // end of class XSRCCOL
|
|
|
|
|
2013-02-08 03:27:12 +01:00
|
|
|
/***********************************************************************/
|
2013-12-16 01:32:47 +01:00
|
|
|
/* This is the class declaration for the Drivers catalog table. */
|
2013-02-08 03:27:12 +01:00
|
|
|
/***********************************************************************/
|
2013-12-16 01:32:47 +01:00
|
|
|
class TDBDRV : public TDBCAT {
|
2013-02-08 03:27:12 +01:00
|
|
|
public:
|
|
|
|
// Constructor
|
2013-12-16 01:32:47 +01:00
|
|
|
TDBDRV(PODEF tdp) : TDBCAT(tdp) {Maxres = tdp->Maxres;}
|
2013-02-08 03:27:12 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// Specific routines
|
2013-02-11 00:31:03 +01:00
|
|
|
virtual PQRYRES GetResult(PGLOBAL g);
|
2013-02-08 03:27:12 +01:00
|
|
|
|
2013-12-16 01:32:47 +01:00
|
|
|
// Members
|
|
|
|
int Maxres; // Returned lines limit
|
|
|
|
}; // end of class TDBDRV
|
2013-02-08 03:27:12 +01:00
|
|
|
|
|
|
|
/***********************************************************************/
|
2013-12-16 01:32:47 +01:00
|
|
|
/* This is the class declaration for the Data Sources catalog table. */
|
2013-02-09 01:08:15 +01:00
|
|
|
/***********************************************************************/
|
2013-12-16 01:32:47 +01:00
|
|
|
class TDBSRC : public TDBDRV {
|
2013-02-09 01:08:15 +01:00
|
|
|
public:
|
|
|
|
// Constructor
|
2013-12-16 01:32:47 +01:00
|
|
|
TDBSRC(PODEF tdp) : TDBDRV(tdp) {}
|
2013-02-09 01:08:15 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// Specific routines
|
2013-02-11 00:31:03 +01:00
|
|
|
virtual PQRYRES GetResult(PGLOBAL g);
|
2013-02-09 01:08:15 +01:00
|
|
|
|
2013-12-16 01:32:47 +01:00
|
|
|
// No additional Members
|
|
|
|
}; // end of class TDBSRC
|
2013-02-09 01:08:15 +01:00
|
|
|
|
|
|
|
/***********************************************************************/
|
2013-02-11 00:31:03 +01:00
|
|
|
/* This is the class declaration for the tables catalog table. */
|
2013-02-08 03:27:12 +01:00
|
|
|
/***********************************************************************/
|
2013-12-16 01:32:47 +01:00
|
|
|
class TDBOTB : public TDBDRV {
|
2013-02-08 03:27:12 +01:00
|
|
|
public:
|
|
|
|
// Constructor
|
2013-02-11 00:31:03 +01:00
|
|
|
TDBOTB(PODEF tdp);
|
2013-02-08 03:27:12 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// Specific routines
|
2013-02-11 00:31:03 +01:00
|
|
|
virtual PQRYRES GetResult(PGLOBAL g);
|
2013-02-08 03:27:12 +01:00
|
|
|
|
|
|
|
// Members
|
|
|
|
char *Dsn; // Points to connection string
|
2013-12-16 01:32:47 +01:00
|
|
|
char *Schema; // Points to schema name or NULL
|
2013-02-11 00:31:03 +01:00
|
|
|
char *Tab; // Points to ODBC table name or pattern
|
2016-07-14 20:12:22 +02:00
|
|
|
char *Tabtyp; // Points to ODBC table type
|
|
|
|
ODBCPARM Ops; // Additional parameters
|
2013-02-11 00:31:03 +01:00
|
|
|
}; // end of class TDBOTB
|
2013-02-09 01:08:15 +01:00
|
|
|
|
|
|
|
/***********************************************************************/
|
2013-02-11 00:31:03 +01:00
|
|
|
/* This is the class declaration for the columns catalog table. */
|
2013-02-09 01:08:15 +01:00
|
|
|
/***********************************************************************/
|
2013-02-11 00:31:03 +01:00
|
|
|
class TDBOCL : public TDBOTB {
|
2013-02-09 01:08:15 +01:00
|
|
|
public:
|
|
|
|
// Constructor
|
2016-07-14 20:12:22 +02:00
|
|
|
TDBOCL(PODEF tdp);
|
2013-02-09 01:08:15 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// Specific routines
|
2013-02-11 00:31:03 +01:00
|
|
|
virtual PQRYRES GetResult(PGLOBAL g);
|
2013-02-09 01:08:15 +01:00
|
|
|
|
2016-07-14 20:12:22 +02:00
|
|
|
// Members
|
|
|
|
char *Colpat; // Points to column pattern
|
2013-02-11 00:31:03 +01:00
|
|
|
}; // end of class TDBOCL
|
|
|
|
|
2013-02-08 03:27:12 +01:00
|
|
|
#endif // !NODBC
|