mirror of
https://github.com/MariaDB/server.git
synced 2025-01-21 22:34:18 +01:00
0219ac1e98
have been created by the last addition of new CONNECT features. The version previous to this one is a preliminary test version and should not be distributed. - Handle indexed UPDATE/DELETE. Previously this was just tested and an error message send when it could not be done. Now CONNECT can do it in all the cases. It is done by a MRR like tchnique by making a list of all update or delete to do, sort them, then execute them. modified: storage/connect/array.cpp storage/connect/array.h storage/connect/filamap.cpp storage/connect/filamap.h storage/connect/filamdbf.cpp storage/connect/filamfix.cpp storage/connect/filamfix.h storage/connect/filamtxt.cpp storage/connect/filamtxt.h storage/connect/filamvct.cpp storage/connect/filamvct.h storage/connect/filamzip.cpp storage/connect/filamzip.h storage/connect/global.h storage/connect/ha_connect.cc storage/connect/ha_connect.h - Differenciate Cardinality that returns a true or estimated table size and GetMaxSize that return a value equal or greater than the table row number. This fixes the errors of non matching opt files. modified: storage/connect/connect.cc storage/connect/tabdos.cpp storage/connect/tabdos.h storage/connect/tabfix.cpp storage/connect/table.cpp storage/connect/tabmac.h storage/connect/tabmysql.cpp storage/connect/tabmysql.h storage/connect/tabodbc.cpp storage/connect/tabodbc.h storage/connect/tabpivot.h storage/connect/tabtbl.cpp storage/connect/tabtbl.h storage/connect/tabutil.cpp storage/connect/tabutil.h storage/connect/tabwmi.h storage/connect/xtable.h - Fix some errors and issues when making index and opt files. Erase opt and index files for void tables. Fix wrong calculation of Block and Last in MakeBlockValues. Invalidate indexes before making opt file. Fully handle blocked variable tables. Make opt file for blocked variable tables even when they have no optimised colums. modified: storage/connect/tabdos.cpp storage/connect/xindex.h - Fix some errors making index Return an error when the allocation is too small (should not really occur now that GetMaxSize is sure) Don't use XXROW index for DBF tables because of soft deleted lines. modified: storage/connect/xindex.cpp - Typo modified: storage/connect/macutil.cpp storage/connect/tabdos.h storage/connect/tabsys.cpp storage/connect/tabsys.h
259 lines
10 KiB
C++
259 lines
10 KiB
C++
// TDBMYSQL.H Olivier Bertrand 2007-2014
|
|
#include "myconn.h" // MySQL connection declares
|
|
|
|
typedef class MYSQLDEF *PMYDEF;
|
|
typedef class TDBMYSQL *PTDBMY;
|
|
typedef class MYSQLCOL *PMYCOL;
|
|
typedef class TDBMYEXC *PTDBMYX;
|
|
typedef class MYXCOL *PMYXCOL;
|
|
typedef class MYSQLC *PMYC;
|
|
|
|
/* ------------------------- MYSQL classes --------------------------- */
|
|
|
|
/***********************************************************************/
|
|
/* MYSQL: table type that are MySQL tables. */
|
|
/* Using embedded MySQL library (or optionally calling a MySQL server)*/
|
|
/***********************************************************************/
|
|
|
|
/***********************************************************************/
|
|
/* MYSQL table. */
|
|
/***********************************************************************/
|
|
class MYSQLDEF : public TABDEF {/* Logical table description */
|
|
friend class TDBMYSQL;
|
|
friend class TDBMYEXC;
|
|
friend class TDBMCL;
|
|
friend class ha_connect;
|
|
public:
|
|
// Constructor
|
|
MYSQLDEF(void);
|
|
|
|
|
|
// Implementation
|
|
virtual const char *GetType(void) {return "MYSQL";}
|
|
inline PSZ GetHostname(void) {return Hostname;};
|
|
inline PSZ GetDatabase(void) {return Database;};
|
|
inline PSZ GetTabname(void) {return Tabname;}
|
|
inline PSZ GetSrcdef(void) {return Srcdef;}
|
|
inline PSZ GetUsername(void) {return Username;};
|
|
inline PSZ GetPassword(void) {return Password;};
|
|
inline int GetPortnumber(void) {return Portnumber;}
|
|
|
|
// Methods
|
|
virtual int Indexable(void) {return 2;}
|
|
virtual bool DefineAM(PGLOBAL g, LPCSTR am, int poff);
|
|
virtual PTDB GetTable(PGLOBAL g, MODE m);
|
|
bool ParseURL(PGLOBAL g, char *url, bool b = true);
|
|
bool GetServerInfo(PGLOBAL g, const char *server_name);
|
|
|
|
protected:
|
|
// Members
|
|
PSZ Hostname; /* Host machine to use */
|
|
PSZ Database; /* Database to be used by server */
|
|
PSZ Tabname; /* External table name */
|
|
PSZ Srcdef; /* The source table SQL definition */
|
|
PSZ Username; /* User logon name */
|
|
PSZ Password; /* Password logon info */
|
|
PSZ Server; /* PServerID */
|
|
PSZ Qrystr; /* The original query */
|
|
int Portnumber; /* MySQL port number (0 = default) */
|
|
int Mxr; /* Maxerr for an Exec table */
|
|
int Quoted; /* Identifier quoting level */
|
|
bool Isview; /* true if this table is a MySQL view */
|
|
bool Bind; /* Use prepared statement on insert */
|
|
bool Delayed; /* Delayed insert */
|
|
bool Xsrc; /* Execution type */
|
|
bool Huge; /* True for big table */
|
|
}; // end of MYSQLDEF
|
|
|
|
/***********************************************************************/
|
|
/* This is the class declaration for the MYSQL table. */
|
|
/***********************************************************************/
|
|
class TDBMYSQL : public TDBASE {
|
|
friend class MYSQLCOL;
|
|
public:
|
|
// Constructor
|
|
TDBMYSQL(PMYDEF tdp);
|
|
TDBMYSQL(PGLOBAL g, PTDBMY tdbp);
|
|
|
|
// Implementation
|
|
virtual AMT GetAmType(void) {return TYPE_AM_MYSQL;}
|
|
virtual PTDB Duplicate(PGLOBAL g) {return (PTDB)new(g) TDBMYSQL(g, this);}
|
|
|
|
// Methods
|
|
virtual PTDB CopyOne(PTABS t);
|
|
//virtual int GetAffectedRows(void) {return AftRows;}
|
|
virtual int GetRecpos(void) {return N;}
|
|
virtual int GetProgMax(PGLOBAL g);
|
|
virtual void ResetDB(void) {N = 0;}
|
|
virtual int RowNumber(PGLOBAL g, bool b = false);
|
|
virtual bool IsView(void) {return Isview;}
|
|
virtual PSZ GetServer(void) {return Server;}
|
|
void SetDatabase(LPCSTR db) {Database = (char*)db;}
|
|
|
|
// Database routines
|
|
virtual PCOL MakeCol(PGLOBAL g, PCOLDEF cdp, PCOL cprec, int n);
|
|
virtual int Cardinality(PGLOBAL g);
|
|
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);
|
|
virtual bool ReadKey(PGLOBAL g, OPVAL op, const void *key, int len);
|
|
|
|
// Specific routines
|
|
bool SetColumnRanks(PGLOBAL g);
|
|
PCOL MakeFieldColumn(PGLOBAL g, char *name);
|
|
PSZ FindFieldColumn(char *name);
|
|
|
|
protected:
|
|
// Internal functions
|
|
bool MakeSelect(PGLOBAL g, bool mx);
|
|
bool MakeInsert(PGLOBAL g);
|
|
int BindColumns(PGLOBAL g);
|
|
int MakeCommand(PGLOBAL g);
|
|
//int MakeUpdate(PGLOBAL g);
|
|
//int MakeDelete(PGLOBAL g);
|
|
int SendCommand(PGLOBAL g);
|
|
|
|
// Members
|
|
MYSQLC Myc; // MySQL connection class
|
|
MYSQL_BIND *Bind; // To the MySQL bind structure array
|
|
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; // External table name
|
|
char *Srcdef; // The source table SQL definition
|
|
char *Server; // The server ID
|
|
char *Query; // Points to SQL query
|
|
char *Qbuf; // Used for not prepared insert
|
|
char *Qrystr; // The original query
|
|
bool Fetched; // True when fetch was done
|
|
bool Isview; // True if this table is a MySQL view
|
|
bool Prep; // Use prepared statement on insert
|
|
bool Delayed; // Use delayed insert
|
|
int m_Rc; // Return code from command
|
|
int AftRows; // The number of affected rows
|
|
int N; // The current table index
|
|
int Port; // MySQL port number (0 = default)
|
|
int Nparm; // The number of statement parameters
|
|
int Quoted; // The identifier quoting level
|
|
}; // end of class TDBMYSQL
|
|
|
|
/***********************************************************************/
|
|
/* Class MYSQLCOL: MySQL table column. */
|
|
/***********************************************************************/
|
|
class MYSQLCOL : public COLBLK {
|
|
friend class TDBMYSQL;
|
|
public:
|
|
// Constructors
|
|
MYSQLCOL(PCOLDEF cdp, PTDB tdbp, PCOL cprec, int i, PSZ am = "MYSQL");
|
|
MYSQLCOL(MYSQL_FIELD *fld, PTDB tdbp, int i, PSZ am = "MYSQL");
|
|
MYSQLCOL(MYSQLCOL *colp, PTDB tdbp); // Constructor used in copy process
|
|
|
|
// Implementation
|
|
virtual int GetAmType(void) {return TYPE_AM_MYSQL;}
|
|
void InitBind(PGLOBAL g);
|
|
|
|
// Methods
|
|
virtual bool SetBuffer(PGLOBAL g, PVAL value, bool ok, bool check);
|
|
virtual void ReadColumn(PGLOBAL g);
|
|
virtual void WriteColumn(PGLOBAL g);
|
|
bool FindRank(PGLOBAL g);
|
|
|
|
protected:
|
|
// Default constructor not to be used
|
|
MYSQLCOL(void) {}
|
|
|
|
// Members
|
|
MYSQL_BIND *Bind; // This column bind structure pointer
|
|
PVAL To_Val; // To value used for Update/Insert
|
|
unsigned long Slen; // Bind string lengh
|
|
int Rank; // Rank (position) number in the query
|
|
}; // end of class MYSQLCOL
|
|
|
|
/***********************************************************************/
|
|
/* This is the class declaration for the exec command MYSQL table. */
|
|
/***********************************************************************/
|
|
class TDBMYEXC : public TDBMYSQL {
|
|
friend class MYXCOL;
|
|
public:
|
|
// Constructors
|
|
TDBMYEXC(PMYDEF tdp);
|
|
TDBMYEXC(PGLOBAL g, PTDBMYX tdbp);
|
|
|
|
// Implementation
|
|
virtual AMT GetAmType(void) {return TYPE_AM_MYX;}
|
|
virtual PTDB Duplicate(PGLOBAL g) {return (PTDB)new(g) TDBMYEXC(g, this);}
|
|
|
|
// Methods
|
|
virtual PTDB CopyOne(PTABS t);
|
|
virtual bool IsView(void) {return Isview;}
|
|
|
|
// 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);
|
|
|
|
protected:
|
|
// Internal functions
|
|
PCMD MakeCMD(PGLOBAL g);
|
|
|
|
// Members
|
|
PCMD Cmdlist; // The commands to execute
|
|
char *Cmdcol; // The name of the Xsrc command column
|
|
bool Shw; // Show warnings
|
|
bool Havew; // True when processing warnings
|
|
bool Isw; // True for warning lines
|
|
int Warnings; // Warnings number
|
|
int Mxr; // Maximum errors before closing
|
|
int Nerr; // Number of errors so far
|
|
}; // end of class TDBMYEXC
|
|
|
|
/***********************************************************************/
|
|
/* Class MYXCOL: MySQL exec command table column. */
|
|
/***********************************************************************/
|
|
class MYXCOL : public MYSQLCOL {
|
|
friend class TDBMYEXC;
|
|
public:
|
|
// Constructors
|
|
MYXCOL(PCOLDEF cdp, PTDB tdbp, PCOL cprec, int i, PSZ am = "MYSQL");
|
|
MYXCOL(MYSQL_FIELD *fld, PTDB tdbp, int i, PSZ am = "MYSQL");
|
|
MYXCOL(MYXCOL *colp, PTDB tdbp); // Constructor used in copy process
|
|
|
|
// Methods
|
|
virtual void ReadColumn(PGLOBAL g);
|
|
virtual void WriteColumn(PGLOBAL g);
|
|
|
|
protected:
|
|
// Default constructor not to be used
|
|
MYXCOL(void) {}
|
|
|
|
// Members
|
|
char *Buffer; // To get returned message
|
|
int Flag; // Column content desc
|
|
}; // end of class MYXCOL
|
|
|
|
/***********************************************************************/
|
|
/* This is the class declaration for the MYSQL column catalog table. */
|
|
/***********************************************************************/
|
|
class TDBMCL : public TDBCAT {
|
|
public:
|
|
// Constructor
|
|
TDBMCL(PMYDEF tdp);
|
|
|
|
protected:
|
|
// Specific routines
|
|
virtual PQRYRES GetResult(PGLOBAL g);
|
|
|
|
// Members
|
|
PSZ Host; // Host machine to use
|
|
PSZ Db; // Database to be used by server
|
|
PSZ Tab; // External table name
|
|
PSZ User; // User logon name
|
|
PSZ Pwd; // Password logon info
|
|
int Port; // MySQL port number (0 = default)
|
|
}; // end of class TDBMCL
|