2013-02-07 13:34:27 +04:00
|
|
|
/************** TabPivot H Declares Source Code File (.H) **************/
|
2013-05-28 17:22:38 +02:00
|
|
|
/* Name: TABPIVOT.H Version 1.5 */
|
2013-02-07 13:34:27 +04:00
|
|
|
/* */
|
2013-05-19 19:25:06 +02:00
|
|
|
/* (C) Copyright to the author Olivier BERTRAND 2005-2013 */
|
2013-02-07 13:34:27 +04:00
|
|
|
/* */
|
|
|
|
/* This file contains the PIVOT classes declares. */
|
|
|
|
/***********************************************************************/
|
2013-05-19 19:25:06 +02:00
|
|
|
typedef class PIVOTDEF *PPIVOTDEF;
|
2013-02-07 13:34:27 +04:00
|
|
|
typedef class TDBPIVOT *PTDBPIVOT;
|
|
|
|
typedef class FNCCOL *PFNCCOL;
|
|
|
|
typedef class SRCCOL *PSRCCOL;
|
|
|
|
|
2013-05-28 21:06:15 +02:00
|
|
|
/***********************************************************************/
|
|
|
|
/* This class is used to generate PIVOT table column definitions. */
|
|
|
|
/***********************************************************************/
|
|
|
|
class PIVAID : public CSORT {
|
|
|
|
friend class FNCCOL;
|
|
|
|
friend class SRCCOL;
|
|
|
|
public:
|
|
|
|
// Constructor
|
2014-04-08 18:18:02 +02:00
|
|
|
PIVAID(const char *tab, const char *src, const char *picol,
|
|
|
|
const char *fncol, const char *skcol, const char *host,
|
|
|
|
const char *db, const char *user, const char *pwd, int port);
|
2013-05-28 21:06:15 +02:00
|
|
|
|
|
|
|
// Methods
|
|
|
|
PQRYRES MakePivotColumns(PGLOBAL g);
|
2014-04-08 18:18:02 +02:00
|
|
|
bool SkipColumn(PCOLRES crp, char *skc);
|
2013-05-28 21:06:15 +02:00
|
|
|
|
|
|
|
// The sorting function
|
|
|
|
virtual int Qcompare(int *, int *);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
// Members
|
|
|
|
MYSQLC Myc; // MySQL connection class
|
|
|
|
char *Host; // Host machine to use
|
|
|
|
char *User; // User logon info
|
|
|
|
char *Pwd; // Password logon info
|
|
|
|
char *Database; // Database to be used by server
|
|
|
|
PQRYRES Qryp; // Points to Query result block
|
|
|
|
char *Tabname; // Name of source table
|
|
|
|
char *Tabsrc; // SQL of source table
|
|
|
|
char *Picol; // Pivot column name
|
|
|
|
char *Fncol; // Function column name
|
2014-04-08 18:18:02 +02:00
|
|
|
char *Skcol; // Skipped columns
|
2013-05-28 21:06:15 +02:00
|
|
|
PVBLK Rblkp; // The value block of the pivot column
|
|
|
|
int Port; // MySQL port number
|
|
|
|
}; // end of class PIVAID
|
|
|
|
|
2013-02-07 13:34:27 +04:00
|
|
|
/* -------------------------- PIVOT classes -------------------------- */
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* PIVOT: table that provides a view of a source table where the */
|
|
|
|
/* pivot column is expended in as many columns as there are distinct */
|
|
|
|
/* values in it and containing the function value matching other cols.*/
|
|
|
|
/***********************************************************************/
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* PIVOT table. */
|
|
|
|
/***********************************************************************/
|
2013-05-10 20:22:21 +02:00
|
|
|
class PIVOTDEF : public PRXDEF { /* Logical table description */
|
2013-02-07 13:34:27 +04:00
|
|
|
friend class TDBPIVOT;
|
|
|
|
public:
|
|
|
|
// Constructor
|
2013-05-10 20:22:21 +02:00
|
|
|
PIVOTDEF(void);
|
2013-02-07 13:34:27 +04:00
|
|
|
|
|
|
|
// Implementation
|
|
|
|
virtual const char *GetType(void) {return "PIVOT";}
|
|
|
|
|
|
|
|
// Methods
|
|
|
|
virtual bool DefineAM(PGLOBAL g, LPCSTR am, int poff);
|
|
|
|
virtual PTDB GetTable(PGLOBAL g, MODE m);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
// Members
|
2013-05-10 20:22:21 +02:00
|
|
|
char *Host; /* Host machine to use */
|
|
|
|
char *User; /* User logon info */
|
|
|
|
char *Pwd; /* Password logon info */
|
|
|
|
char *DB; /* Database to be used by server */
|
|
|
|
char *Tabname; /* Name of source table */
|
2013-02-07 13:34:27 +04:00
|
|
|
char *Tabsrc; /* The source table SQL description */
|
2013-05-10 20:22:21 +02:00
|
|
|
char *Picol; /* The pivot column */
|
2013-02-07 13:34:27 +04:00
|
|
|
char *Fncol; /* The function column */
|
|
|
|
char *Function; /* The function applying to group by */
|
|
|
|
bool GBdone; /* True if tabname as group by format */
|
2013-05-10 20:22:21 +02:00
|
|
|
bool Accept; /* TRUE if no match is accepted */
|
|
|
|
int Port; /* MySQL port number */
|
2013-02-07 13:34:27 +04:00
|
|
|
}; // end of PIVOTDEF
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* This is the class declaration for the PIVOT table. */
|
|
|
|
/***********************************************************************/
|
2013-05-10 20:22:21 +02:00
|
|
|
class TDBPIVOT : public TDBPRX {
|
2013-02-07 13:34:27 +04:00
|
|
|
friend class FNCCOL;
|
|
|
|
public:
|
|
|
|
// Constructor
|
|
|
|
TDBPIVOT(PPIVOTDEF tdp);
|
|
|
|
|
|
|
|
// Implementation
|
|
|
|
virtual AMT GetAmType(void) {return TYPE_AM_PIVOT;}
|
|
|
|
|
|
|
|
// Methods
|
|
|
|
virtual int GetRecpos(void) {return N;}
|
|
|
|
virtual void ResetDB(void) {N = 0;}
|
|
|
|
virtual int RowNumber(PGLOBAL g, bool b = FALSE);
|
|
|
|
|
|
|
|
// Database routines
|
|
|
|
virtual PCOL MakeCol(PGLOBAL g, PCOLDEF cdp, PCOL cprec, int n);
|
2014-08-07 17:59:21 +02:00
|
|
|
virtual int Cardinality(PGLOBAL g) {return (g) ? 10 : 0;}
|
2013-02-07 13:34:27 +04:00
|
|
|
virtual int GetMaxSize(PGLOBAL g);
|
|
|
|
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);
|
|
|
|
|
|
|
|
protected:
|
2013-05-19 19:25:06 +02:00
|
|
|
// Internal routines
|
2013-05-22 13:35:21 +02:00
|
|
|
bool FindDefaultColumns(PGLOBAL g);
|
2013-05-19 19:25:06 +02:00
|
|
|
bool GetSourceTable(PGLOBAL g);
|
|
|
|
bool MakePivotColumns(PGLOBAL g);
|
|
|
|
bool MakeViewColumns(PGLOBAL g);
|
2013-02-07 13:34:27 +04:00
|
|
|
|
|
|
|
// Members
|
2013-05-10 20:22:21 +02:00
|
|
|
char *Host; // Host machine to use
|
|
|
|
char *User; // User logon info
|
|
|
|
char *Pwd; // Password logon info
|
|
|
|
char *Database; // Database to be used by server
|
|
|
|
char *Tabname; // Name of source table
|
|
|
|
char *Tabsrc; // SQL of source table
|
|
|
|
char *Picol; // Pivot column name
|
|
|
|
char *Fncol; // Function column name
|
|
|
|
char *Function; // The function applying to group by
|
|
|
|
PCOL Fcolp; // To the function column in source
|
|
|
|
PCOL Xcolp; // To the pivot column in source
|
|
|
|
PCOL Dcolp; // To the dump column
|
|
|
|
bool GBdone; // True when subtable is "Group by"
|
|
|
|
bool Accept; // TRUE if no match is accepted
|
|
|
|
int Mult; // Multiplication factor
|
|
|
|
int Ncol; // The number of generated columns
|
|
|
|
int N; // The current table index
|
|
|
|
int M; // The occurence rank
|
|
|
|
int Port; // MySQL port number
|
|
|
|
BYTE FileStatus; // 0: First 1: Rows 2: End-of-File
|
|
|
|
BYTE RowFlag; // 0: Ok, 1: Same, 2: Skip
|
2013-02-07 13:34:27 +04:00
|
|
|
}; // end of class TDBPIVOT
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* Class FNCCOL: for the multiple generated column. */
|
|
|
|
/***********************************************************************/
|
|
|
|
class FNCCOL : public COLBLK {
|
|
|
|
friend class TDBPIVOT;
|
|
|
|
public:
|
|
|
|
// Constructor
|
2013-05-10 20:22:21 +02:00
|
|
|
FNCCOL(PCOLDEF cdp, PTDB tdbp, PCOL cprec, int i);
|
2013-02-07 13:34:27 +04:00
|
|
|
|
|
|
|
// Implementation
|
|
|
|
virtual int GetAmType(void) {return TYPE_AM_FNC;}
|
|
|
|
|
|
|
|
// Methods
|
|
|
|
virtual void Reset(void) {}
|
2013-05-10 20:22:21 +02:00
|
|
|
bool InitColumn(PGLOBAL g);
|
|
|
|
bool CompareColumn(void);
|
2013-02-07 13:34:27 +04:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// Member
|
2013-05-10 20:22:21 +02:00
|
|
|
PVAL Hval; // The value containing the header
|
|
|
|
PCOL Xcolp;
|
2013-02-07 13:34:27 +04:00
|
|
|
}; // end of class FNCCOL
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* Class SRCCOL: for other source columns. */
|
|
|
|
/***********************************************************************/
|
2013-05-10 20:22:21 +02:00
|
|
|
class SRCCOL : public PRXCOL {
|
2013-02-07 13:34:27 +04:00
|
|
|
friend class TDBPIVOT;
|
|
|
|
public:
|
|
|
|
// Constructors
|
2013-05-10 20:22:21 +02:00
|
|
|
SRCCOL(PCOLDEF cdp, PTDB tdbp, PCOL cprec, int n);
|
2013-02-07 13:34:27 +04:00
|
|
|
|
|
|
|
// Implementation
|
|
|
|
virtual int GetAmType(void) {return TYPE_AM_SRC;}
|
|
|
|
|
|
|
|
// Methods
|
2015-01-27 19:18:51 +01:00
|
|
|
using PRXCOL::Init;
|
2013-02-07 13:34:27 +04:00
|
|
|
virtual void Reset(void) {}
|
|
|
|
void SetColumn(void);
|
2017-02-16 18:01:48 +01:00
|
|
|
virtual bool Init(PGLOBAL g, PTDB tp);
|
2013-05-10 20:22:21 +02:00
|
|
|
bool CompareLast(void);
|
2013-02-07 13:34:27 +04:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// Default constructor not to be used
|
|
|
|
SRCCOL(void) {}
|
|
|
|
|
|
|
|
// Members
|
|
|
|
}; // end of class SRCCOL
|
2013-07-08 11:22:32 +04:00
|
|
|
|
|
|
|
PQRYRES PivotColumns(PGLOBAL g, const char *tab, const char *src,
|
|
|
|
const char *picol, const char *fncol,
|
2014-04-08 18:18:02 +02:00
|
|
|
const char *skcol, const char *host,
|
|
|
|
const char *db, const char *user,
|
|
|
|
const char *pwd, int port);
|