1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318
|
/* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; version 2 of the License.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02111-1307 USA */
#ifndef SQL_GET_DIAGNOSTICS_H
#define SQL_GET_DIAGNOSTICS_H
/** Diagnostics information forward reference. */
class Diagnostics_information;
/**
Sql_cmd_get_diagnostics represents a GET DIAGNOSTICS statement.
The GET DIAGNOSTICS statement retrieves exception or completion
condition information from a diagnostics area, usually pertaining
to the last non-diagnostic SQL statement that was executed.
*/
class Sql_cmd_get_diagnostics : public Sql_cmd
{
public:
/**
Constructor, used to represent a GET DIAGNOSTICS statement.
@param info Diagnostics information to be obtained.
*/
Sql_cmd_get_diagnostics(Diagnostics_information *info)
: m_info(info)
{}
virtual enum_sql_command sql_command_code() const
{
return SQLCOM_GET_DIAGNOSTICS;
}
virtual bool execute(THD *thd);
private:
/** The information to be obtained. */
Diagnostics_information *m_info;
};
/**
Represents the diagnostics information to be obtained.
Diagnostic information is made available through statement
information and condition information items.
*/
class Diagnostics_information : public Sql_alloc
{
public:
/**
Which diagnostics area to access.
Only CURRENT is supported for now.
*/
enum Which_area
{
/** Access the first diagnostics area. */
CURRENT_AREA
};
/** Set which diagnostics area to access. */
void set_which_da(Which_area area)
{ m_area= area; }
/** Get which diagnostics area to access. */
Which_area get_which_da(void) const
{ return m_area; }
/**
Aggregate diagnostics information.
@param thd The current thread.
@param da The diagnostics area.
@retval false on success.
@retval true on error
*/
virtual bool aggregate(THD *thd, const Diagnostics_area *da) = 0;
protected:
/**
Diagnostics_information objects are allocated in thd->mem_root.
Do not rely on the destructor for any cleanup.
*/
virtual ~Diagnostics_information()
{
DBUG_ASSERT(false);
}
/**
Evaluate a diagnostics information item in a specific context.
@param thd The current thread.
@param diag_item The diagnostics information item.
@param ctx The context to evaluate the item.
@retval false on success.
@retval true on error.
*/
template <typename Diag_item, typename Context>
bool evaluate(THD *thd, Diag_item *diag_item, Context ctx)
{
Item *value;
/* Get this item's value. */
if (! (value= diag_item->get_value(thd, ctx)))
return true;
/* Set variable/parameter value. */
return diag_item->set_value(thd, &value);
}
private:
/** Which diagnostics area to access. */
Which_area m_area;
};
/**
A diagnostics information item. Used to associate a specific
diagnostics information item to a target variable.
*/
class Diagnostics_information_item : public Sql_alloc
{
public:
/**
Set a value for this item.
@param thd The current thread.
@param value The obtained value.
@retval false on success.
@retval true on error.
*/
bool set_value(THD *thd, Item **value);
protected:
/**
Constructor, used to represent a diagnostics information item.
@param target A target that gets the value of this item.
*/
Diagnostics_information_item(Item *target)
: m_target(target)
{}
/**
Diagnostics_information_item objects are allocated in thd->mem_root.
Do not rely on the destructor for any cleanup.
*/
virtual ~Diagnostics_information_item()
{
DBUG_ASSERT(false);
}
private:
/** The target variable that will receive the value of this item. */
Item *m_target;
};
/**
A statement information item.
*/
class Statement_information_item : public Diagnostics_information_item
{
public:
/** The name of a statement information item. */
enum Name
{
NUMBER,
ROW_COUNT
};
/**
Constructor, used to represent a statement information item.
@param name The name of this item.
@param target A target that gets the value of this item.
*/
Statement_information_item(Name name, Item *target)
: Diagnostics_information_item(target), m_name(name)
{}
/** Obtain value of this statement information item. */
Item *get_value(THD *thd, const Diagnostics_area *da);
private:
/** The name of this statement information item. */
Name m_name;
};
/**
Statement information.
@remark Provides information about the execution of a statement.
*/
class Statement_information : public Diagnostics_information
{
public:
/**
Constructor, used to represent the statement information of a
GET DIAGNOSTICS statement.
@param items List of requested statement information items.
*/
Statement_information(List<Statement_information_item> *items)
: m_items(items)
{}
/** Obtain statement information in the context of a diagnostics area. */
bool aggregate(THD *thd, const Diagnostics_area *da);
private:
/* List of statement information items. */
List<Statement_information_item> *m_items;
};
/**
A condition information item.
*/
class Condition_information_item : public Diagnostics_information_item
{
public:
/**
The name of a condition information item.
*/
enum Name
{
CLASS_ORIGIN,
SUBCLASS_ORIGIN,
CONSTRAINT_CATALOG,
CONSTRAINT_SCHEMA,
CONSTRAINT_NAME,
CATALOG_NAME,
SCHEMA_NAME,
TABLE_NAME,
COLUMN_NAME,
CURSOR_NAME,
MESSAGE_TEXT,
MYSQL_ERRNO,
RETURNED_SQLSTATE
};
/**
Constructor, used to represent a condition information item.
@param name The name of this item.
@param target A target that gets the value of this item.
*/
Condition_information_item(Name name, Item *target)
: Diagnostics_information_item(target), m_name(name)
{}
/** Obtain value of this condition information item. */
Item *get_value(THD *thd, const Sql_condition *cond);
private:
/** The name of this condition information item. */
Name m_name;
/** Create an string item to represent a condition item string. */
Item *make_utf8_string_item(THD *thd, const String *str);
};
/**
Condition information.
@remark Provides information about conditions raised during the
execution of a statement.
*/
class Condition_information : public Diagnostics_information
{
public:
/**
Constructor, used to represent the condition information of a
GET DIAGNOSTICS statement.
@param cond_number_expr Number that identifies the diagnostic condition.
@param items List of requested condition information items.
*/
Condition_information(Item *cond_number_expr,
List<Condition_information_item> *items)
: m_cond_number_expr(cond_number_expr), m_items(items)
{}
/** Obtain condition information in the context of a diagnostics area. */
bool aggregate(THD *thd, const Diagnostics_area *da);
private:
/**
Number that identifies the diagnostic condition for which
information is to be obtained.
*/
Item *m_cond_number_expr;
/** List of condition information items. */
List<Condition_information_item> *m_items;
};
#endif
|