12 #ifndef ROOT_TMySQLStatement
13 #define ROOT_TMySQLStatement
20 #if MYSQL_VERSION_ID < 40100
21 typedef struct {
int dummy; } MYSQL_STMT;
22 typedef struct {
int dummy; } MYSQL_BIND;
27 #ifndef MARIADB_VERSION_ID
28 #if MYSQL_VERSION_ID > 80000 && MYSQL_VERSION_ID < 100000
33 class TMySQLStatement :
public TSQLStatement {
53 Int_t fIterationCount;
56 Bool_t IsSetParsMode()
const {
return fWorkingMode==1; }
57 Bool_t IsResultSetMode()
const {
return fWorkingMode==2; }
59 Bool_t SetSQLParamType(Int_t npar,
int sqltype, Bool_t sig, ULong_t sqlsize = 0);
61 long double ConvertToNumeric(Int_t npar);
62 const char *ConvertToString(Int_t npar);
65 void SetBuffersNumber(Int_t n);
67 void *BeforeSet(
const char* method, Int_t npar, Int_t sqltype, Bool_t sig = kTRUE, ULong_t size = 0);
69 static ULong64_t fgAllocSizeLimit;
72 TMySQLStatement(
const TMySQLStatement&);
73 TMySQLStatement &operator=(
const TMySQLStatement&);
76 TMySQLStatement(MYSQL_STMT* stmt, Bool_t errout = kTRUE);
77 virtual ~TMySQLStatement();
79 static ULong_t GetAllocSizeLimit() {
return fgAllocSizeLimit; }
80 static void SetAllocSizeLimit(ULong_t sz) { fgAllocSizeLimit = sz; }
82 virtual void Close(Option_t * =
"");
84 virtual Int_t GetBufferLength()
const {
return 1; }
85 virtual Int_t GetNumParameters();
87 virtual Bool_t SetNull(Int_t npar);
88 virtual Bool_t SetInt(Int_t npar, Int_t value);
89 virtual Bool_t SetUInt(Int_t npar, UInt_t value);
90 virtual Bool_t SetLong(Int_t npar, Long_t value);
91 virtual Bool_t SetLong64(Int_t npar, Long64_t value);
92 virtual Bool_t SetULong64(Int_t npar, ULong64_t value);
93 virtual Bool_t SetDouble(Int_t npar, Double_t value);
94 virtual Bool_t SetString(Int_t npar,
const char* value, Int_t maxsize = 256);
95 virtual Bool_t SetBinary(Int_t npar,
void* mem, Long_t size, Long_t maxsize = 0x1000);
96 virtual Bool_t SetDate(Int_t npar, Int_t year, Int_t month, Int_t day);
97 virtual Bool_t SetTime(Int_t npar, Int_t hour, Int_t min, Int_t sec);
98 virtual Bool_t SetDatime(Int_t npar, Int_t year, Int_t month, Int_t day, Int_t hour, Int_t min, Int_t sec);
99 using TSQLStatement::SetTimestamp;
100 virtual Bool_t SetTimestamp(Int_t npar, Int_t year, Int_t month, Int_t day, Int_t hour, Int_t min, Int_t sec, Int_t frac = 0);
102 virtual Bool_t NextIteration();
104 virtual Bool_t Process();
105 virtual Int_t GetNumAffectedRows();
107 virtual Bool_t StoreResult();
108 virtual Int_t GetNumFields();
109 virtual const char *GetFieldName(Int_t nfield);
110 virtual Bool_t NextResultRow();
112 virtual Bool_t IsNull(Int_t npar);
113 virtual Int_t GetInt(Int_t npar);
114 virtual UInt_t GetUInt(Int_t npar);
115 virtual Long_t GetLong(Int_t npar);
116 virtual Long64_t GetLong64(Int_t npar);
117 virtual ULong64_t GetULong64(Int_t npar);
118 virtual Double_t GetDouble(Int_t npar);
119 virtual const char *GetString(Int_t npar);
120 virtual Bool_t GetBinary(Int_t npar,
void* &mem, Long_t& size);
121 virtual Bool_t GetDate(Int_t npar, Int_t& year, Int_t& month, Int_t& day);
122 virtual Bool_t GetTime(Int_t npar, Int_t& hour, Int_t& min, Int_t& sec);
123 virtual Bool_t GetDatime(Int_t npar, Int_t& year, Int_t& month, Int_t& day, Int_t& hour, Int_t& min, Int_t& sec);
124 using TSQLStatement::GetTimestamp;
125 virtual Bool_t GetTimestamp(Int_t npar, Int_t& year, Int_t& month, Int_t& day, Int_t& hour, Int_t& min, Int_t& sec, Int_t&);
127 ClassDef(TMySQLStatement, 0);