mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-31 02:46:29 +01:00 
			
		
		
		
	 db0c28eff8
			
		
	
	
	db0c28eff8
	
	
	
		
			
			Find and fix missing virtual override markings. Updates cmake maintainer flags to include -Wsuggest-override and -Winconsistent-missing-override.
		
			
				
	
	
		
			200 lines
		
	
	
	
		
			8.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			200 lines
		
	
	
	
		
			8.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /************** TabPivot H Declares Source Code File (.H) **************/
 | |
| /*  Name: TABPIVOT.H    Version 1.5                                    */
 | |
| /*                                                                     */
 | |
| /*  (C) Copyright to the author Olivier BERTRAND          2005-2013    */
 | |
| /*                                                                     */
 | |
| /*  This file contains the PIVOT classes declares.                     */
 | |
| /***********************************************************************/
 | |
| typedef class PIVOTDEF *PPIVOTDEF;
 | |
| typedef class TDBPIVOT *PTDBPIVOT;
 | |
| typedef class FNCCOL   *PFNCCOL;
 | |
| typedef class SRCCOL   *PSRCCOL;
 | |
| 
 | |
| /***********************************************************************/
 | |
| /*  This class is used to generate PIVOT table column definitions.     */
 | |
| /***********************************************************************/
 | |
| class PIVAID : public CSORT {
 | |
|   friend class FNCCOL;
 | |
|   friend class SRCCOL;
 | |
|  public:
 | |
|   // Constructor
 | |
|   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);
 | |
| 
 | |
|   // Methods
 | |
|   PQRYRES MakePivotColumns(PGLOBAL g);
 | |
|   bool    SkipColumn(PCOLRES crp, char *skc);
 | |
| 
 | |
|   // The sorting function
 | |
|   int  Qcompare(int *, int *) override;
 | |
| 
 | |
|  protected:
 | |
|   // Members
 | |
|   MYSQLC  Myc;                      // MySQL connection class
 | |
|   PCSZ    Host;                     // Host machine to use
 | |
| 	PCSZ    User;                     // User logon info
 | |
| 	PCSZ    Pwd;                      // Password logon info
 | |
| 	PCSZ    Database;                 // Database to be used by server
 | |
|   PQRYRES Qryp;                     // Points to Query result block
 | |
| 	PCSZ    Tabname;                  // Name of source table
 | |
| 	PCSZ    Tabsrc;                   // SQL of source table
 | |
| 	PCSZ    Picol;                    // Pivot column name
 | |
| 	PCSZ    Fncol;                    // Function column name
 | |
| 	PCSZ    Skcol;                    // Skipped columns
 | |
|   PVBLK   Rblkp;                    // The value block of the pivot column
 | |
|   int     Port;                     // MySQL port number
 | |
|   }; // end of class PIVAID
 | |
| 
 | |
| /* -------------------------- 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.                                                       */
 | |
| /***********************************************************************/
 | |
| class PIVOTDEF : public PRXDEF {          /* Logical table description */
 | |
|   friend class TDBPIVOT;
 | |
|  public:
 | |
|   // Constructor
 | |
|   PIVOTDEF(void);
 | |
| 
 | |
|   // Implementation
 | |
|   const char *GetType(void) override {return "PIVOT";}
 | |
| 
 | |
|   // Methods
 | |
|   bool DefineAM(PGLOBAL g, LPCSTR am, int poff) override;
 | |
|   PTDB GetTable(PGLOBAL g, MODE m) override;
 | |
| 
 | |
|  protected:
 | |
|   // Members
 | |
|   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                   */
 | |
|   char  *Tabsrc;             /* The source table SQL description       */
 | |
|   char  *Picol;              /* The pivot column                       */
 | |
|   char  *Fncol;              /* The function column                    */
 | |
|   char  *Function;           /* The function applying to group by      */
 | |
|   bool   GBdone;             /* True if tabname as group by format     */
 | |
|   bool   Accept;             /* TRUE if no match is accepted           */
 | |
|   int    Port;               /* MySQL port number                      */
 | |
|   }; // end of PIVOTDEF
 | |
| 
 | |
| /***********************************************************************/
 | |
| /*  This is the class declaration for the PIVOT table.                 */
 | |
| /***********************************************************************/
 | |
| class TDBPIVOT : public TDBPRX {
 | |
|   friend class FNCCOL;
 | |
|  public:
 | |
|   // Constructor
 | |
|   TDBPIVOT(PPIVOTDEF tdp);
 | |
| 
 | |
|   // Implementation
 | |
|   AMT  GetAmType(void) override {return TYPE_AM_PIVOT;}
 | |
| 
 | |
|   // Methods
 | |
|   int  GetRecpos(void) override {return N;}
 | |
|   void ResetDB(void) override {N = 0;}
 | |
|   int  RowNumber(PGLOBAL g, bool b = FALSE) override;
 | |
| 
 | |
|   // Database routines
 | |
|   PCOL MakeCol(PGLOBAL g, PCOLDEF cdp, PCOL cprec, int n) override;
 | |
|   int  Cardinality(PGLOBAL g) override {return (g) ? 10 : 0;}
 | |
|   int  GetMaxSize(PGLOBAL g) override;
 | |
|   bool OpenDB(PGLOBAL g) override;
 | |
|   int  ReadDB(PGLOBAL g) override;
 | |
|   int  WriteDB(PGLOBAL g) override;
 | |
|   int  DeleteDB(PGLOBAL g, int irc) override;
 | |
|   void CloseDB(PGLOBAL g) override;
 | |
| 
 | |
|  protected:
 | |
|   // Internal routines
 | |
|           bool FindDefaultColumns(PGLOBAL g);
 | |
|           bool GetSourceTable(PGLOBAL g);
 | |
|           bool MakePivotColumns(PGLOBAL g);
 | |
|           bool MakeViewColumns(PGLOBAL g);
 | |
| 
 | |
|   // Members
 | |
|   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 occurrence rank
 | |
|   int     Port;                   // MySQL port number 
 | |
|   BYTE    FileStatus;             // 0: First 1: Rows 2: End-of-File
 | |
|   BYTE    RowFlag;                // 0: Ok, 1: Same, 2: Skip
 | |
|   }; // end of class TDBPIVOT
 | |
| 
 | |
| /***********************************************************************/
 | |
| /*  Class FNCCOL: for the multiple generated column.                   */
 | |
| /***********************************************************************/
 | |
| class FNCCOL : public COLBLK {
 | |
|   friend class TDBPIVOT;
 | |
|  public:
 | |
|   // Constructor
 | |
|   FNCCOL(PCOLDEF cdp, PTDB tdbp, PCOL cprec, int i);
 | |
| 
 | |
|   // Implementation
 | |
|   int  GetAmType(void) override {return TYPE_AM_FNC;}
 | |
| 
 | |
|   // Methods
 | |
|   void Reset(void) override {}
 | |
|           bool InitColumn(PGLOBAL g);
 | |
|           bool CompareColumn(void);
 | |
| 
 | |
|  protected:
 | |
|   // Member
 | |
|   PVAL Hval;      // The value containing the header
 | |
|   PCOL Xcolp;
 | |
|   }; // end of class FNCCOL
 | |
| 
 | |
| /***********************************************************************/
 | |
| /*  Class SRCCOL: for other source columns.                            */
 | |
| /***********************************************************************/
 | |
| class SRCCOL : public PRXCOL {
 | |
|   friend class TDBPIVOT;
 | |
|  public:
 | |
|   // Constructors
 | |
|   SRCCOL(PCOLDEF cdp, PTDB tdbp, PCOL cprec, int n);
 | |
| 
 | |
|   // Implementation
 | |
|   int  GetAmType(void) override {return TYPE_AM_SRC;}
 | |
| 
 | |
|   // Methods
 | |
|   using PRXCOL::Init;
 | |
|   void Reset(void) override {}
 | |
|           void SetColumn(void);
 | |
|   bool Init(PGLOBAL g, PTDB tp) override;
 | |
|           bool CompareLast(void);
 | |
| 
 | |
|  protected:
 | |
|   // Default constructor not to be used
 | |
|   SRCCOL(void) = default;
 | |
| 
 | |
|   // Members
 | |
|   }; // end of class SRCCOL
 | |
| 
 | |
| PQRYRES PivotColumns(PGLOBAL g, 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);
 |