MySQL 9.2.0
Source Code Documentation
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages Concepts
sql_parse.h
Go to the documentation of this file.
1/* Copyright (c) 2006, 2024, Oracle and/or its affiliates.
2
3 This program is free software; you can redistribute it and/or modify
4 it under the terms of the GNU General Public License, version 2.0,
5 as published by the Free Software Foundation.
6
7 This program is designed to work with certain software (including
8 but not limited to OpenSSL) that is licensed under separate terms,
9 as designated in a particular file or component or in included license
10 documentation. The authors of MySQL hereby grant you an additional
11 permission to link the program and your derivative works with the
12 separately licensed software that they have either included with
13 the program or referenced in the documentation.
14
15 This program is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 GNU General Public License, version 2.0, for more details.
19
20 You should have received a copy of the GNU General Public License
21 along with this program; if not, write to the Free Software
22 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
23
24#ifndef SQL_PARSE_INCLUDED
25#define SQL_PARSE_INCLUDED
26
27#include <stddef.h>
28#include <sys/types.h>
29
30#include "lex_string.h"
31#include "my_command.h"
32#include "my_sqlcommand.h"
34#include "mysql_com.h" // enum_server_command
35#include "sql/handler.h" // enum_schema_tables
36#include "sql/system_variables.h" // System_variables
38
39struct mysql_rwlock_t;
40template <typename T>
41class SQL_I_List;
42
43/**
44 @addtogroup GROUP_PARSER
45 @{
46*/
47
48class Comp_creator;
49class Item;
51class Parser_state;
52class THD;
53class Table_ident;
54struct LEX;
55struct LEX_USER;
56struct ORDER;
57struct Parse_context;
58class Table_ref;
59union COM_DATA;
60enum class enum_sp_type;
61
62extern "C" int test_if_data_home_dir(const char *dir);
63
64bool stmt_causes_implicit_commit(const THD *thd, uint mask);
65
66#ifndef NDEBUG
68#endif
69
70bool parse_sql(THD *thd, Parser_state *parser_state,
71 Object_creation_ctx *creation_ctx);
72
73void free_items(Item *item);
74void cleanup_items(Item *item);
75void bind_fields(Item *first);
76
77Comp_creator *comp_eq_creator(bool invert);
79Comp_creator *comp_ge_creator(bool invert);
80Comp_creator *comp_gt_creator(bool invert);
81Comp_creator *comp_le_creator(bool invert);
82Comp_creator *comp_lt_creator(bool invert);
83Comp_creator *comp_ne_creator(bool invert);
84
85int prepare_schema_table(THD *thd, LEX *lex, Table_ident *table_ident,
86 enum enum_schema_tables schema_table_idx);
87void get_default_definer(THD *thd, LEX_USER *definer);
90bool check_string_char_length(const LEX_CSTRING &str, const char *err_msg,
91 size_t max_char_length, const CHARSET_INFO *cs,
92 bool no_error);
95 const CHARSET_INFO **to);
98 const CHARSET_INFO **to);
104bool alloc_query(THD *thd, const char *packet, size_t packet_length);
105void dispatch_sql_command(THD *thd, Parser_state *parser_state,
106 bool is_retry = false);
110 const char *db_name, const char *sp_name);
112 bool sp_did_not_exist, const char *db_name,
113 const char *sp_name);
114int mysql_execute_command(THD *thd, bool first_level = false);
115bool do_command(THD *thd);
116bool dispatch_command(THD *thd, const COM_DATA *com_data,
118bool prepare_index_and_data_dir_path(THD *thd, const char **data_file_name,
119 const char **index_file_name,
120 const char *table_name);
121int append_file_to_dir(THD *thd, const char **filename_ptr,
122 const char *table_name);
123void execute_init_command(THD *thd, LEX_STRING *init_command,
124 mysql_rwlock_t *var_lock);
126void add_join_on(Table_ref *b, Item *expr);
128 Table_ref *right_op);
129void init_sql_command_flags(void);
132bool shutdown(THD *thd, enum mysql_enum_shutdown_level level);
133bool show_precheck(THD *thd, LEX *lex, bool lock);
135
136/* Variables */
137
138extern uint sql_command_flags[];
139
140/**
141 Map from enumeration values of type enum_server_command to
142 descriptions of type std::string.
143
144 In this context, a "command" is a type code for a remote procedure
145 call in the client-server protocol; for instance, a "connect" or a
146 "ping" or a "query".
147
148 The getter functions use @@terminology_use_previous to
149 decide which version of the name to use, for names that depend on
150 it.
151*/
153 private:
154 /**
155 Array indexed by enum_server_command, where each element is a
156 description string.
157 */
158 static const std::string m_names[];
159 /**
160 Command whose name depends on @@terminology_use_previous.
161
162 Currently, there is only one such command, so we use a single
163 member variable. In case we ever change any other command name
164 and control the use of the old or new name using
165 @@terminology_use_previous, we need to change the
166 following three members into some collection type, e.g.,
167 std::unordered_set.
168 */
170 /**
171 Name to use when compatibility is enabled.
172 */
173 static const std::string m_replace_str;
174 /**
175 The version when the name was changed.
176 */
179 /**
180 Given a system_variable object, returns the string to use for
181 m_replace_com, according to the setting of
182 terminology_use_previous stored in the object.
183
184 @param sysvars The System_variables object holding the
185 configuration that should be considered when doing the translation.
186
187 @return The instrumentation name that was in use in the configured
188 version, for m_replace_com.
189 */
190 static const std::string &translate(const System_variables &sysvars);
191 /**
192 Cast an integer to enum_server_command, and assert it is in range.
193
194 @param cmd The integer value
195 @return The enum_server_command
196 */
198 assert(cmd >= 0);
199 assert(cmd <= COM_END);
200 return static_cast<enum_server_command>(cmd);
201 }
202
203 public:
204 /**
205 Return a description string for a given enum_server_command.
206
207 This bypasses @@terminology_use_previous and acts as if
208 it was set to NONE.
209
210 @param cmd The enum_server_command
211 @retval The description string
212 */
213 static const std::string &str_notranslate(enum_server_command cmd) {
214 return m_names[cmd];
215 }
216 /**
217 Return a description string for an integer that is the numeric
218 value of an enum_server_command.
219
220 This bypasses @@terminology_use_previous and acts as if
221 it was set to NONE.
222
223 @param cmd The integer value
224 @retval The description string
225 */
226 static const std::string &str_notranslate(int cmd) {
227 return str_notranslate(int_to_cmd(cmd));
228 }
229 /**
230 Return a description string for a given enum_server_command.
231
232 This takes @@session.terminology_use_previous into
233 account, and returns an old name if one has been defined and the
234 option is enabled.
235
236 @param cmd The enum_server_command
237 @retval The description string
238 */
239 static const std::string &str_session(enum_server_command cmd);
240 /**
241 Return a description string for a given enum_server_command.
242
243 This takes @@global.terminology_use_previous into
244 account, and returns an old name if one has been defined and the
245 option is enabled.
246
247 @param cmd The enum_server_command
248 @retval The description string
249 */
250 static const std::string &str_global(enum_server_command cmd);
251 /**
252 Return a description string for an integer that is the numeric
253 value of an enum_server_command.
254
255 This takes @@session.terminology_use_previous into
256 account, and returns an old name if one has been defined and the
257 option is enabled.
258
259 @param cmd The integer value
260 @retval The description string
261 */
262 static const std::string &str_session(int cmd) {
263 return str_session(int_to_cmd(cmd));
264 }
265};
266
268
269/**
270 @brief This function checks if the sql_command is one that identifies the
271 boundaries (begin, end or savepoint) of a transaction.
272
273 @note this is used for replication purposes.
274
275 @param command The parsed SQL_COMM to check.
276 @return true if this is either a BEGIN, COMMIT, SAVEPOINT, ROLLBACK,
277 ROLLBACK_TO_SAVEPOINT.
278 @return false any other SQL command.
279 */
281
282/**
283 @brief This function checks if the sql_command is one that identifies the
284 boundaries (begin, end or savepoint) of an XA transaction. It does not
285 consider PREPARE statements.
286
287 @note this is used for replication purposes.
288
289 @param command The parsed SQL_COMM to check.
290 @return true if this is either a XA_START, XA_END, XA_COMMIT, XA_ROLLBACK.
291 @return false any other SQL command.
292 */
294
295bool all_tables_not_ok(THD *thd, Table_ref *tables);
297
298// TODO: remove after refactoring of ALTER DATABASE:
299bool set_default_charset(HA_CREATE_INFO *create_info,
300 const CHARSET_INFO *value);
301// TODO: remove after refactoring of ALTER DATABASE:
302bool set_default_collation(HA_CREATE_INFO *create_info,
303 const CHARSET_INFO *value);
304
305bool sp_process_definer(THD *);
306
307/* Bits in sql_command_flags */
308
309#define CF_CHANGES_DATA (1U << 0)
310/* The 2nd bit is unused -- it used to be CF_HAS_ROW_COUNT. */
311#define CF_STATUS_COMMAND (1U << 2)
312#define CF_SHOW_TABLE_COMMAND (1U << 3)
313#define CF_WRITE_LOGS_COMMAND (1U << 4)
314/**
315 Must be set for SQL statements that may contain
316 Item expressions and/or use joins and tables.
317 Indicates that the parse tree of such statement may
318 contain rule-based optimizations that depend on metadata
319 (i.e. number of columns in a table), and consequently
320 that the statement must be re-prepared whenever
321 referenced metadata changes. Must not be set for
322 statements that themselves change metadata, e.g. RENAME,
323 ALTER and other DDL, since otherwise will trigger constant
324 reprepare. Consequently, complex item expressions and
325 joins are currently prohibited in these statements.
326*/
327#define CF_REEXECUTION_FRAGILE (1U << 5)
328/**
329 Implicitly commit before the SQL statement is executed.
330
331 Statements marked with this flag will cause any active
332 transaction to end (commit) before proceeding with the
333 command execution.
334
335 This flag should be set for statements that probably can't
336 be rolled back or that do not expect any previously metadata
337 locked tables.
338*/
339#define CF_IMPLICIT_COMMIT_BEGIN (1U << 6)
340/**
341 Implicitly commit after the SQL statement.
342
343 Statements marked with this flag are automatically committed
344 at the end of the statement.
345
346 This flag should be set for statements that will implicitly
347 open and take metadata locks on system tables that should not
348 be carried for the whole duration of a active transaction.
349*/
350#define CF_IMPLICIT_COMMIT_END (1U << 7)
351/**
352 CF_IMPLICIT_COMMIT_BEGIN and CF_IMPLICIT_COMMIT_END are used
353 to ensure that the active transaction is implicitly committed
354 before and after every DDL statement and any statement that
355 modifies our currently non-transactional system tables.
356*/
357#define CF_AUTO_COMMIT_TRANS (CF_IMPLICIT_COMMIT_BEGIN | CF_IMPLICIT_COMMIT_END)
358
359/**
360 Diagnostic statement.
361 Diagnostic statements:
362 - SHOW WARNING
363 - SHOW ERROR
364 - GET DIAGNOSTICS (WL#2111)
365 do not modify the Diagnostics Area during execution.
366*/
367#define CF_DIAGNOSTIC_STMT (1U << 8)
368
369/**
370 Identifies statements that may generate row events
371 and that may end up in the binary log.
372*/
373#define CF_CAN_GENERATE_ROW_EVENTS (1U << 9)
374
375/**
376 Identifies statements which may deal with temporary tables and for which
377 temporary tables should be pre-opened to simplify privilege checks.
378*/
379#define CF_PREOPEN_TMP_TABLES (1U << 10)
380
381/**
382 Identifies statements for which open handlers should be closed in the
383 beginning of the statement.
384*/
385#define CF_HA_CLOSE (1U << 11)
386
387/**
388 Identifies statements that can be explained with EXPLAIN.
389*/
390#define CF_CAN_BE_EXPLAINED (1U << 12)
391
392/** Identifies statements which may generate an optimizer trace */
393#define CF_OPTIMIZER_TRACE (1U << 14)
394
395/**
396 Identifies statements that should always be disallowed in
397 read only transactions.
398*/
399#define CF_DISALLOW_IN_RO_TRANS (1U << 15)
400
401/**
402 Identifies statements and commands that can be used with Protocol Plugin
403*/
404#define CF_ALLOW_PROTOCOL_PLUGIN (1U << 16)
405
406/**
407 Identifies statements (typically DDL) which needs auto-commit mode
408 temporarily turned off.
409
410 @note This is necessary to prevent InnoDB from automatically committing
411 InnoDB transaction each time data-dictionary tables are closed
412 after being updated.
413
414 @note This is also necessary for ACL DDL, so the code which
415 saves GTID state or slave state in the system tables at the
416 commit time works correctly. This code does statement commit
417 on low-level (see System_table_access:: close_table()) and
418 thus can pre-maturely commit DDL if @@autocommit=1.
419*/
420#define CF_NEEDS_AUTOCOMMIT_OFF (1U << 17)
421
422/**
423 Identifies statements which can return rows of data columns (SELECT, SHOW ...)
424*/
425#define CF_HAS_RESULT_SET (1U << 18)
426
427/**
428 Identifies DDL statements which can be atomic.
429 Having the bit ON does not yet define an atomic.
430 The property is used both on the master and slave.
431 On the master atomicity infers the binlog and gtid_executed system table.
432 On the slave it more involves the slave info table.
433
434 @note At the momemnt of declaration the covered DDL subset coincides
435 with the of CF_NEEDS_AUTOCOMMIT_OFF.
436*/
437#define CF_POTENTIAL_ATOMIC_DDL (1U << 19)
438
439/**
440 Statement is depending on the ACL cache, which can be disabled by the
441 --skip-grant-tables server option.
442*/
443#define CF_REQUIRE_ACL_CACHE (1U << 20)
444
445/**
446 Identifies statements as SHOW commands using INFORMATION_SCHEMA system views.
447*/
448#define CF_SHOW_USES_SYSTEM_VIEW (1U << 21)
449
450/* Bits in server_command_flags */
451
452/**
453 Skip the increase of the global query id counter. Commonly set for
454 commands that are stateless (won't cause any change on the server
455 internal states). This is made obsolete as query id is incremented
456 for ping and statistics commands as well because of race condition
457 (Bug#58785).
458*/
459#define CF_SKIP_QUERY_ID (1U << 0)
460
461/**
462 Skip the increase of the number of statements that clients have
463 sent to the server. Commonly used for commands that will cause
464 a statement to be executed but the statement might have not been
465 sent by the user (ie: stored procedure).
466*/
467#define CF_SKIP_QUESTIONS (1U << 1)
468
469/**
470 1U << 16 is reserved for Protocol Plugin statements and commands
471*/
472
473/**
474 @} (end of group GROUP_PARSER)
475*/
476
477#endif /* SQL_PARSE_INCLUDED */
Map from enumeration values of type enum_server_command to descriptions of type std::string.
Definition: sql_parse.h:152
static constexpr terminology_use_previous::enum_compatibility_version m_replace_version
The version when the name was changed.
Definition: sql_parse.h:178
static enum_server_command int_to_cmd(int cmd)
Cast an integer to enum_server_command, and assert it is in range.
Definition: sql_parse.h:197
static constexpr enum_server_command m_replace_com
Command whose name depends on @terminology_use_previous.
Definition: sql_parse.h:169
static const std::string & str_notranslate(int cmd)
Return a description string for an integer that is the numeric value of an enum_server_command.
Definition: sql_parse.h:226
static const std::string & str_notranslate(enum_server_command cmd)
Return a description string for a given enum_server_command.
Definition: sql_parse.h:213
static const std::string & str_session(int cmd)
Return a description string for an integer that is the numeric value of an enum_server_command.
Definition: sql_parse.h:262
Abstract factory interface for creating comparison predicates.
Definition: item_cmpfunc.h:524
Base class that is used to represent any kind of expression in a relational query.
Definition: item.h:930
Object_creation_ctx – interface for creation context of database objects (views, stored routines,...
Definition: table.h:204
Internal state of the parser.
Definition: sql_lexer_parser_state.h:44
Simple intrusive linked list.
Definition: sql_list.h:48
For each client connection we create a separate thread with THD serving as a thread/connection descri...
Definition: sql_lexer_thd.h:36
Definition: sql_lex.h:308
Definition: table.h:2900
Definition: sp_head.h:124
int test_if_data_home_dir(const char *dir)
Definition: sql_parse.cc:6983
bool check_host_name(const LEX_CSTRING &str)
Check that host name string is valid.
Definition: sql_parse.cc:7022
int mysql_execute_command(THD *thd, bool first_level=false)
Execute command saved in thd and lex->sql_command.
Definition: sql_parse.cc:3013
void execute_init_command(THD *thd, LEX_STRING *init_command, mysql_rwlock_t *var_lock)
Definition: sql_parse.cc:1231
void statement_id_to_session(THD *thd)
Definition: sql_parse.cc:5245
void add_to_list(SQL_I_List< ORDER > &list, ORDER *order)
save order by and tables in own lists.
Definition: sql_parse.cc:5679
bool is_log_table_write_query(enum enum_sql_command command)
Check if a sql command is allowed to write to log tables.
Definition: sql_parse.cc:1211
bool mysql_test_parse_for_slave(THD *thd)
Usable by the replication SQL thread only: just parse a query to know if it can be ignored because of...
Definition: sql_parse.cc:5469
bool all_tables_not_ok(THD *thd, Table_ref *tables)
Returns true if all tables should be ignored.
Definition: sql_parse.cc:295
bool prepare_index_and_data_dir_path(THD *thd, const char **data_file_name, const char **index_file_name, const char *table_name)
prepares the index and data directory path.
Definition: sql_parse.cc:6627
bool shutdown(THD *thd, enum mysql_enum_shutdown_level level)
Shutdown the mysqld server.
Definition: sql_parse.cc:2537
Comp_creator * comp_equal_creator(bool invert)
Definition: sql_parse.cc:6701
void add_automatic_sp_privileges(THD *thd, enum_sp_type sp_type, const char *db_name, const char *sp_name)
Definition: sql_parse.cc:2889
bool remove_automatic_sp_privileges(THD *thd, enum_sp_type sp_type, bool sp_did_not_exist, const char *db_name, const char *sp_name)
Definition: sql_parse.cc:2963
bool do_command(THD *thd)
Read one command from connection and execute it (query or simple command).
Definition: sql_parse.cc:1336
Comp_creator * comp_le_creator(bool invert)
Definition: sql_parse.cc:6714
bool is_normal_transaction_boundary_stmt(enum enum_sql_command command)
This function checks if the sql_command is one that identifies the boundaries (begin,...
Definition: sql_parse.cc:302
Comp_creator * comp_eq_creator(bool invert)
Definition: sql_parse.cc:6697
bool is_xa_transaction_boundary_stmt(enum enum_sql_command command)
This function checks if the sql_command is one that identifies the boundaries (begin,...
Definition: sql_parse.cc:317
bool is_explainable_query(enum enum_sql_command command)
Definition: sql_parse.cc:1201
bool show_precheck(THD *thd, LEX *lex, bool lock)
Do special checking for SHOW statements.
Definition: sql_parse.cc:5095
bool stmt_causes_implicit_commit(const THD *thd, uint mask)
Returns whether the command in thd->lex->sql_command should cause an implicit commit.
Definition: sql_parse.cc:405
const CHARSET_INFO * get_bin_collation(const CHARSET_INFO *cs)
Definition: sql_parse.cc:6459
bool sqlcom_can_generate_row_events(enum enum_sql_command command)
Definition: sql_parse.cc:1192
bool set_default_charset(HA_CREATE_INFO *create_info, const CHARSET_INFO *value)
Definition: parse_tree_nodes.cc:2239
bool some_non_temp_table_to_be_updated(THD *thd, Table_ref *tables)
Definition: sql_parse.cc:380
bool merge_sp_var_charset_and_collation(const CHARSET_INFO *charset, const CHARSET_INFO *collation, const CHARSET_INFO **to)
Definition: sql_parse.cc:7326
int append_file_to_dir(THD *thd, const char **filename_ptr, const char *table_name)
If pointer is not a null pointer, append filename to it.
Definition: sql_parse.cc:6667
LEX_USER * create_default_definer(THD *thd)
Create default definer for the specified THD.
Definition: sql_parse.cc:6853
Comp_creator * comp_gt_creator(bool invert)
Definition: sql_parse.cc:6710
bool alloc_query(THD *thd, const char *packet, size_t packet_length)
Read query from packet and store in thd->query.
Definition: sql_parse.cc:2656
void bind_fields(Item *first)
Bind Item fields to Field objects.
Definition: sql_parse.cc:1320
void create_table_set_open_action_and_adjust_tables(LEX *lex)
Set proper open mode and table type for element representing target table of CREATE TABLE statement,...
Definition: sql_parse.cc:6782
Comp_creator * comp_ne_creator(bool invert)
Definition: sql_parse.cc:6722
void turn_parser_debug_on()
enum_sp_type
enum_sp_type defines type codes of stored programs.
Definition: sql_lex.h:225
bool sp_process_definer(THD *)
Definition: sql_parse.cc:2681
int prepare_schema_table(THD *thd, LEX *lex, Table_ident *table_ident, enum enum_schema_tables schema_table_idx)
Create a Table_ref object for an INFORMATION_SCHEMA table.
Definition: sql_parse.cc:2594
void add_join_on(Table_ref *b, Item *expr)
Add an ON condition to the second operand of a JOIN ... ON.
Definition: sql_parse.cc:6442
Comp_creator * comp_lt_creator(bool invert)
Definition: sql_parse.cc:6718
void mysql_reset_thd_for_next_command(THD *thd)
Reset the part of THD responsible for the state of command processing.
Definition: sql_parse.cc:5158
void killall_non_super_threads(THD *thd)
Definition: sql_parse.cc:6608
bool parse_sql(THD *thd, Parser_state *parser_state, Object_creation_ctx *creation_ctx)
Transform an SQL statement into an AST that is ready for resolving, using the supplied parser state a...
Definition: sql_parse.cc:7123
bool dispatch_command(THD *thd, const COM_DATA *com_data, enum enum_server_command command)
Perform one connection-level (COM_XXXX) command.
Definition: sql_parse.cc:1741
LEX_USER * get_current_user(THD *thd, LEX_USER *user)
Returns information about user or current user.
Definition: sql_parse.cc:6875
bool is_update_query(enum enum_sql_command command)
Definition: sql_parse.cc:1196
Comp_creator * comp_ge_creator(bool invert)
Definition: sql_parse.cc:6706
uint sql_command_flags[]
Mark all commands that somehow changes a table.
Definition: sql_parse.cc:511
void init_sql_command_flags(void)
Definition: sql_parse.cc:514
void get_default_definer(THD *thd, LEX_USER *definer)
Set the specified definer to the default value, which is the current user in the thread.
Definition: sql_parse.cc:6810
bool set_default_collation(HA_CREATE_INFO *create_info, const CHARSET_INFO *value)
Definition: parse_tree_nodes.cc:2263
bool merge_charset_and_collation(const CHARSET_INFO *charset, const CHARSET_INFO *collation, const CHARSET_INFO **to)
(end of group Runtime_Environment)
Definition: sql_parse.cc:7312
void free_items(Item *item)
Definition: sql_parse.cc:1297
void dispatch_sql_command(THD *thd, Parser_state *parser_state, bool is_retry=false)
Parse an SQL command from a text string and pass the resulting AST to the query executor.
Definition: sql_parse.cc:5270
void cleanup_items(Item *item)
This works because items are allocated with (*THR_MALLOC)->Alloc().
Definition: sql_parse.cc:1310
bool push_new_name_resolution_context(Parse_context *pc, Table_ref *left_op, Table_ref *right_op)
Push a new name resolution context for a JOIN ... ON clause to the context stack of a query block.
Definition: sql_parse.cc:6414
bool check_string_char_length(const LEX_CSTRING &str, const char *err_msg, size_t max_char_length, const CHARSET_INFO *cs, bool no_error)
Definition: sql_parse.cc:6954
static const std::string & str_session(enum_server_command cmd)
Return a description string for a given enum_server_command.
Definition: sql_parse.cc:272
static const std::string & str_global(enum_server_command cmd)
Return a description string for a given enum_server_command.
Definition: sql_parse.cc:278
static const std::string m_replace_str
Name to use when compatibility is enabled.
Definition: sql_parse.h:173
static const std::string & translate(const System_variables &sysvars)
Given a system_variable object, returns the string to use for m_replace_com, according to the setting...
Definition: sql_parse.cc:263
static const std::string m_names[]
Array indexed by enum_server_command, where each element is a description string.
Definition: sql_parse.h:158
mysql_enum_shutdown_level
We want levels to be in growing order of hardness (because we use number comparisons).
Definition: mysql_com.h:1006
A better implementation of the UNIX ctype(3) library.
static mi_bit_type mask[]
Definition: mi_packrec.cc:141
enum_server_command
A list of all MySQL protocol commands.
Definition: my_command.h:48
@ COM_END
Not a real command.
Definition: my_command.h:102
@ COM_REGISTER_SLAVE
Definition: my_command.h:74
enum_sql_command
Definition: my_sqlcommand.h:46
Common definition between mysql server & client.
char * user
Definition: mysqladmin.cc:67
const char * collation
Definition: audit_api_message_emit.cc:184
std::string str(const mysqlrouter::ConfigGenerator::Options::Endpoint &ep)
Definition: config_generator.cc:1117
const std::string charset("charset")
Definition: commit_order_queue.h:34
std::string dir
Double write files location.
Definition: buf0dblwr.cc:77
Provides atomic access in shared-exclusive modes.
Definition: shared_spin_lock.h:79
const char * table_name
Definition: rules_table_service.cc:56
const char * db_name
Definition: rules_table_service.cc:55
enum_compatibility_version
Enumeration holding the possible values for @terminology_use_previous.
Definition: terminology_use_previous_enum.h:48
@ BEFORE_8_0_26
Use names that were in use up to 8.0.25, inclusive.
Definition: terminology_use_previous_enum.h:52
std::list< T, ut::allocator< T > > list
Specialization of list which uses ut_allocator.
Definition: ut0new.h:2880
enum_schema_tables
Definition: handler.h:924
Definition: m_ctype.h:421
Struct to hold information about the table that should be created.
Definition: handler.h:3253
Definition: table.h:2767
The LEX object currently serves three different purposes:
Definition: sql_lex.h:3958
Definition: mysql_lex_string.h:40
Definition: mysql_lex_string.h:35
Definition: table.h:289
Environment data for the contextualization phase.
Definition: parse_tree_node_base.h:421
Definition: system_variables.h:203
An instrumented rwlock structure.
Definition: mysql_rwlock_bits.h:51
Definition: com_data.h:104
command
Definition: version_token.cc:284