2017-02-16 18:01:48 +01:00
|
|
|
/*************** Tabext H Declares Source Code File (.H) ***************/
|
2019-01-25 13:02:40 +01:00
|
|
|
/* Name: TABEXT.H Version 1.1 */
|
2017-02-16 18:01:48 +01:00
|
|
|
/* */
|
2019-01-25 13:02:40 +01:00
|
|
|
/* (C) Copyright to the author Olivier BERTRAND 2017 - 2019 */
|
2017-02-16 18:01:48 +01:00
|
|
|
/* */
|
|
|
|
/* This is the EXTDEF, TABEXT and EXTCOL classes definitions. */
|
|
|
|
/***********************************************************************/
|
|
|
|
|
|
|
|
#ifndef __TABEXT_H
|
2017-10-15 16:13:23 +02:00
|
|
|
#define __TABEXT_H
|
2017-02-16 18:01:48 +01:00
|
|
|
|
|
|
|
#include "reldef.h"
|
|
|
|
|
|
|
|
typedef class ALIAS *PAL;
|
|
|
|
|
|
|
|
class ALIAS : public BLOCK {
|
|
|
|
public:
|
|
|
|
ALIAS(PAL x, PSZ n, PSZ a, bool h)
|
|
|
|
{Next = x, Name = n, Alias = a, Having = h;}
|
|
|
|
|
|
|
|
PAL Next;
|
|
|
|
PSZ Name;
|
|
|
|
PSZ Alias;
|
|
|
|
bool Having;
|
|
|
|
}; // end of class ALIAS
|
|
|
|
|
|
|
|
// Condition filter structure
|
|
|
|
class CONDFIL : public BLOCK {
|
|
|
|
public:
|
|
|
|
// Constructor
|
2017-05-23 19:35:50 +02:00
|
|
|
CONDFIL(uint idx, AMT type);
|
2017-02-16 18:01:48 +01:00
|
|
|
|
|
|
|
// Functions
|
|
|
|
int Init(PGLOBAL g, PHC hc);
|
|
|
|
const char *Chk(const char *cln, bool *h);
|
|
|
|
|
|
|
|
// Members
|
2017-05-23 19:35:50 +02:00
|
|
|
//const Item *Cond;
|
2017-02-16 18:01:48 +01:00
|
|
|
AMT Type;
|
|
|
|
uint Idx;
|
|
|
|
OPVAL Op;
|
|
|
|
PCMD Cmds;
|
|
|
|
PAL Alist;
|
|
|
|
bool All;
|
|
|
|
bool Bd;
|
|
|
|
bool Hv;
|
|
|
|
char *Body;
|
|
|
|
char *Having;
|
|
|
|
}; // end of class CONDFIL
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* This class corresponds to the data base description for external */
|
|
|
|
/* tables of type MYSQL, ODBC, JDBC... */
|
|
|
|
/***********************************************************************/
|
|
|
|
class DllExport EXTDEF : public TABDEF { /* EXT table */
|
|
|
|
friend class TDBEXT;
|
|
|
|
public:
|
|
|
|
// Constructor
|
|
|
|
EXTDEF(void); // Constructor
|
|
|
|
|
|
|
|
// Implementation
|
2024-06-12 15:46:26 +02:00
|
|
|
const char *GetType(void) override { return "EXT"; }
|
2017-05-23 19:35:50 +02:00
|
|
|
inline PCSZ GetTabname(void) { return Tabname; }
|
|
|
|
inline PCSZ GetTabschema(void) { return Tabschema; }
|
|
|
|
inline PCSZ GetUsername(void) { return Username; };
|
|
|
|
inline PCSZ GetPassword(void) { return Password; };
|
2017-02-16 18:01:48 +01:00
|
|
|
inline PSZ GetTabcat(void) { return Tabcat; }
|
|
|
|
inline PSZ GetSrcdef(void) { return Srcdef; }
|
|
|
|
inline char GetSep(void) { return (Sep) ? *Sep : 0; }
|
|
|
|
inline int GetQuoted(void) { return Quoted; }
|
2022-10-21 14:26:06 +02:00
|
|
|
inline PSZ GetQchar(void) { return Qchar; }
|
2017-02-16 18:01:48 +01:00
|
|
|
inline int GetOptions(void) { return Options; }
|
|
|
|
|
|
|
|
// Methods
|
2024-06-12 15:46:26 +02:00
|
|
|
int Indexable(void) override { return 2; }
|
|
|
|
bool DefineAM(PGLOBAL g, LPCSTR am, int poff) override;
|
2017-02-16 18:01:48 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// Members
|
2017-05-23 19:35:50 +02:00
|
|
|
PCSZ Tabname; /* External table name */
|
|
|
|
PCSZ Tabschema; /* External table schema */
|
|
|
|
PCSZ Username; /* User connect name */
|
|
|
|
PCSZ Password; /* Password connect info */
|
2017-02-16 18:01:48 +01:00
|
|
|
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 */
|
|
|
|
//PSZ Alias; /* Column alias list */
|
|
|
|
PSZ Phpos; /* Place holer positions */
|
|
|
|
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 */
|
|
|
|
}; // end of EXTDEF
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* This is the base class for all external tables. */
|
|
|
|
/***********************************************************************/
|
|
|
|
class DllExport TDBEXT : public TDB {
|
2017-07-02 22:29:31 +02:00
|
|
|
friend class JAVAConn;
|
|
|
|
friend class JMgoConn;
|
2017-02-16 18:01:48 +01:00
|
|
|
public:
|
|
|
|
// Constructors
|
|
|
|
TDBEXT(EXTDEF *tdp);
|
|
|
|
TDBEXT(PTDBEXT tdbp);
|
|
|
|
|
|
|
|
// Implementation
|
|
|
|
|
|
|
|
// Properties
|
2024-06-12 15:46:26 +02:00
|
|
|
bool IsRemote(void) override { return true; }
|
2017-02-16 18:01:48 +01:00
|
|
|
|
|
|
|
// Methods
|
2024-06-12 15:46:26 +02:00
|
|
|
PCSZ GetServer(void) override { return "Remote"; }
|
|
|
|
int GetRecpos(void) override;
|
2017-02-16 18:01:48 +01:00
|
|
|
|
|
|
|
// Database routines
|
2024-06-12 15:46:26 +02:00
|
|
|
int GetMaxSize(PGLOBAL g) override;
|
|
|
|
int GetProgMax(PGLOBAL g) override;
|
2017-02-16 18:01:48 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// Internal functions
|
2017-08-29 17:35:27 +02:00
|
|
|
virtual bool MakeSrcdef(PGLOBAL g);
|
2017-02-16 18:01:48 +01:00
|
|
|
virtual bool MakeSQL(PGLOBAL g, bool cnt);
|
|
|
|
//virtual bool MakeInsert(PGLOBAL g);
|
|
|
|
virtual bool MakeCommand(PGLOBAL g);
|
2019-01-25 13:02:40 +01:00
|
|
|
void RemoveConst(PGLOBAL g, char *stmt);
|
2017-05-23 19:35:50 +02:00
|
|
|
int Decode(PCSZ utf, char *buf, size_t n);
|
2017-02-16 18:01:48 +01:00
|
|
|
|
|
|
|
// Members
|
|
|
|
PQRYRES Qrp; // Points to storage result
|
|
|
|
PSTRG Query; // Constructed SQL query
|
2017-05-23 19:35:50 +02:00
|
|
|
PCSZ TableName; // Points to ODBC table name
|
|
|
|
PCSZ Schema; // Points to ODBC table Schema
|
|
|
|
PCSZ User; // User connect info
|
|
|
|
PCSZ Pwd; // Password connect info
|
2017-02-16 18:01:48 +01:00
|
|
|
char *Catalog; // Points to ODBC table Catalog
|
|
|
|
char *Srcdef; // The source table SQL definition
|
|
|
|
char *Count; // Points to count(*) SQL statement
|
2017-05-23 19:35:50 +02:00
|
|
|
//char *Where; // Points to local where clause
|
2017-02-16 18:01:48 +01:00
|
|
|
char *Quote; // The identifier quoting character
|
|
|
|
char *MulConn; // Used for multiple ODBC tables
|
|
|
|
char *DBQ; // The address part of Connect string
|
|
|
|
char *Qrystr; // The original query
|
|
|
|
char Sep; // The decimal separator
|
|
|
|
int Options; // Connect options
|
|
|
|
int Cto; // Connect timeout
|
|
|
|
int Qto; // Query timeout
|
|
|
|
int Quoted; // The identifier quoting level
|
|
|
|
int Fpos; // Position of last read record
|
|
|
|
int Curpos; // Cursor position of last fetch
|
|
|
|
int AftRows; // The number of affected rows
|
|
|
|
int Rows; // Rowset size
|
|
|
|
int CurNum; // Current buffer line number
|
|
|
|
int Rbuf; // Number of lines read in buffer
|
|
|
|
int BufSize; // Size of connect string buffer
|
|
|
|
int Nparm; // The number of statement parameters
|
|
|
|
int Memory; // 0: No 1: Alloc 2: Put 3: Get
|
|
|
|
int Ncol; // The column number (JDBC)
|
|
|
|
bool Scrollable; // Use scrollable cursor
|
|
|
|
bool Placed; // True for position reading
|
|
|
|
}; // end of class TDBEXT
|
|
|
|
|
|
|
|
/***********************************************************************/
|
2017-07-02 22:29:31 +02:00
|
|
|
/* Virtual class EXTCOL: external column. */
|
2017-02-16 18:01:48 +01:00
|
|
|
/***********************************************************************/
|
|
|
|
class DllExport EXTCOL : public COLBLK {
|
|
|
|
friend class TDBEXT;
|
|
|
|
public:
|
|
|
|
// Constructor
|
2017-05-23 19:35:50 +02:00
|
|
|
EXTCOL(PCOLDEF cdp, PTDB tdbp, PCOL cprec, int i, PCSZ am);
|
2017-02-16 18:01:48 +01:00
|
|
|
EXTCOL(PEXTCOL colp, PTDB tdbp); // Constructor used in copy process
|
|
|
|
|
|
|
|
// Implementation
|
|
|
|
inline int GetRank(void) { return Rank; }
|
|
|
|
inline void SetRank(int k) { Rank = k; }
|
|
|
|
//inline PVBLK GetBlkp(void) {return Blkp;}
|
|
|
|
inline void SetCrp(PCOLRES crp) { Crp = crp; }
|
|
|
|
|
|
|
|
// Methods
|
2024-06-12 15:46:26 +02:00
|
|
|
bool SetBuffer(PGLOBAL g, PVAL value, bool ok, bool check) override;
|
|
|
|
void ReadColumn(PGLOBAL) override = 0;
|
|
|
|
void WriteColumn(PGLOBAL) override = 0;
|
2017-02-16 18:01:48 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// Constructor for count(*) column
|
|
|
|
EXTCOL(void);
|
|
|
|
|
|
|
|
// Members
|
|
|
|
PCOLRES Crp; // To storage result
|
|
|
|
void *Bufp; // To extended buffer
|
|
|
|
PVBLK Blkp; // To Value Block
|
|
|
|
PVAL To_Val; // To value used for Insert
|
|
|
|
int Rank; // Rank (position) number in the query
|
|
|
|
//int Flag; // ???
|
|
|
|
}; // end of class EXTCOL
|
|
|
|
|
|
|
|
#endif // __TABEXT_H
|