MySQL 8.0.40
Source Code Documentation
show.h
Go to the documentation of this file.
1/* Copyright (c) 2016, 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_DD_SHOW_H
25#define SQL_DD_SHOW_H
26
27class Item;
28class String;
29class THD;
30class Query_block;
31class Table_ident;
32struct YYLTYPE;
33typedef YYLTYPE POS;
34
35namespace dd {
36namespace info_schema {
37
38/**
39 Build a substitute query for SHOW CHARSETS.
40
41 For command like,
42 @code
43 SHOW CHARACTER SET [ LIKE 'pattern' | WHERE expr ]
44 @endcode
45
46 We build following,
47 @code
48 SELECT * FROM
49 (SELECT CHARACTER_SET_NAME as `Charset`,
50 DESCRIPTION as `Description`,
51 DEFAULT_COLLATE_NAME as `Default collation`,
52 MAXLEN as `Maxlen`
53 FROM information_schema.character_sets) character_sets
54 [ WHERE Charset LIKE "<value>" | WHERE @<where_clause@> ]
55 ORDER BY `Charset`;
56 @endcode
57
58 @param pos - YYLTYPE position of parsing context.
59 @param thd - Current thread.
60 @param wild - The value of LIKE clause.
61 @param where_cond - @<where_clause@> clause provided by user.
62
63 @returns pointer to Query_block on success, NULL otherwise.
64*/
66 const String *wild,
67 Item *where_cond);
68
69/**
70 Build a substitute query for SHOW COLLATION.
71
72 For command like,
73 @code
74 SHOW COLLATION [ LIKE 'pattern' | WHERE expr ]
75 @endcode
76
77 We build following,
78 @code
79 SELECT * FROM
80 (SELECT COLLATION_NAME as `Collation`,
81 CHARACTER_SET_NAME as `Charset`,
82 ID as `Id`,
83 IS_COMPILED as `Compiled`,
84 SORTLEN as `Sortlen`,
85 PAD_ATTRIBUTE as `Pad_attribute`,
86 FROM information_schema.collations) collations
87 [ WHERE Collation LIKE "<value>" | WHERE @<where_clause@> ]
88 ORDER BY `Collation`;
89 @endcode
90
91 @param pos - YYLTYPE position of parsing context.
92 @param thd - Current thread.
93 @param wild - The value of LIKE clause.
94 @param where_cond - @<where_clause@> clause provided by user.
95
96 @returns pointer to Query_block on success, NULL otherwise.
97*/
99 const String *wild, Item *where_cond);
100
101/**
102 Build a substitute query for SHOW DATABASES.
103
104 For command like,
105 @code
106 SHOW DATABASES [ LIKE 'pattern' | WHERE expr ]
107 @endcode
108
109 We build following,
110 @code
111 SELECT Database FROM
112 (SELECT SCHEMA_NAME as `Database`,
113 FROM information_schema.schemata) schemata
114 [ WHERE Database LIKE "<value>" | WHERE @<where_clause@> ]
115 ORDER BY `Database`;
116 @endcode
117
118 @param pos - YYLTYPE position of parsing context.
119 @param thd - Current thread.
120 @param wild - The value of LIKE clause.
121 @param where_cond - @<where_clause@> clause provided by user.
122
123 @returns pointer to Query_block on success, NULL otherwise.
124*/
125Query_block *build_show_databases_query(const POS &pos, THD *thd, String *wild,
126 Item *where_cond);
127
128/**
129 Build a substitute query for SHOW TABLES / TABLE STATUS.
130
131 For command like,
132 @code
133 SHOW [FULL] TABLES [{FROM | IN} db_name]
134 [LIKE 'pattern' | WHERE expr]
135 OR
136 SHOW TABLE STATUS [{FROM | IN} db_name]
137 [LIKE 'pattern' | WHERE expr]
138 @endcode
139
140 We build following,
141 @code
142 SELECT `Table`,
143 `Table_type`, <-- only with 'FULL'
144
145 // For SHOW TABLE STATUS
146 `Engine`,
147 `Version`,
148 `Row_format`,
149 `Rows`,
150 `Avg_row_length`,
151 `Data_length`,
152 `Max_data_length`,
153 `Index_length`,
154 `Data_free`,
155 `Auto_increment`,
156 `Create_time`,
157 `Update_time`,
158 `Check_time`,
159 `Collation`,
160 `Checksum`,
161 `Create_options`,
162 `Comment`
163 FROM
164 (SELECT TABLE_SCHEMA AS `Database`,
165 TABLE_NAME as `Table`,
166 TABLE_TYPE AS `Table_type`, <-- only with 'FULL'
167
168 // For SHOW TABLE STATUS
169 ENGINE AS `Engine`,
170 VERSION AS `Version`,
171 ROW_FORMAT AS `Row_format`,
172 TABLE_ROWS AS `Rows`,
173 AVG_ROW_LENGTH AS `Avg_row_length`,
174 DATA_LENGTH AS `Data_length`,
175 MAX_DATA_LENGTH AS `Max_data_length`,
176 INDEX_LENGTH AS `Index_length`,
177 DATA_FREE AS `Data_free`,
178 AUTO_INCREMENT AS `Auto_increment`,
179 CREATE_TIME AS `Create_time`,
180 UPDATE_TIME AS `Update_time`,
181 CHECK_TIME AS `Check_time`,
182 TABLE_COLLATION AS `Collation`,
183 CHECKSUM AS `Checksum`,
184 CREATE_OPTIONS AS `Create_options`,
185 TABLE_COMMENT AS `Comment`
186 FROM information_schema.tables) tables
187 WHERE Database == '<value>' <-- Default DB or IN clause
188 AND
189 [ Table LIKE "<value>" | @<where_clause@> ]
190 ORDER BY `Table`;
191 @endcode
192
193 Note that the thd->lex->verbose == true would mean user has
194 provide keyword 'FULL'.
195
196 @param pos - YYLTYPE position of parsing context.
197 @param thd - Current thread.
198 @param wild - The value of LIKE clause.
199 @param where_cond - @<where_clause@> clause provided by user.
200 @param include_status_fields - If we are handling SHOW TABLE STATUS
201
202 @returns pointer to Query_block on success, NULL otherwise.
203*/
204Query_block *build_show_tables_query(const POS &pos, THD *thd, String *wild,
205 Item *where_cond,
206 bool include_status_fields);
207
208/**
209 Build a substitute query for SHOW COLUMNS/FIELDS OR DESCRIBE.
210
211 For command like,
212 @code
213 SHOW [FULL] COLUMNS
214 {FROM | IN} tbl_name
215 [{FROM | IN} db_name]
216 [LIKE 'pattern' | WHERE expr]
217 OR
218 DESCRIBE tbl_name
219 @endcode
220
221 We build following,
222 @code
223 SELECT Field,
224 Type,
225 Collation, <-- only with 'FULL'
226 Null,
227 Key,
228 Default,
229 Extra,
230 Privileges, <-- only with 'FULL'
231 Comment <-- only with 'FULL'
232 FROM
233 (SELECT TABLE_SCHEMA AS Database,
234 TABLE_NAME AS Table,
235 COLUMN_NAME AS Field,
236 COLUMN_TYPE AS Type,
237 COLLATION_NAME AS Collation, <-- only with 'FULL'
238 IS_NULLABLE AS Null,
239 COLUMN_KEY AS Key,
240 COLUMN_DEFAULT AS Default,
241 EXTRA AS Extra,
242 PRIVILEGES AS Privileges, <-- only with 'FULL'
243 COLUMN_COMMENT AS Comment, <-- only with 'FULL'
244 ORDINAL_POSITION AS Oridinal_position
245 FROM information_schema.columns) columns
246 WHERE Database == '<value>' <-- Default DB or db_name
247 AND
248 Table == 'value' <-- tbl_name
249 AND
250 [ Field LIKE "<value>" | @<where_clause@> ]
251 ORDER BY `Ordinal_position`;
252 @endcode
253
254 Note that the thd->lex->verbose == true would mean user has
255 provide keyword 'FULL'.
256
257 @param pos - YYLTYPE position of parsing context.
258 @param thd - Current thread.
259 @param table_ident - Database and Table name of table being used.
260 @param wild - The value of LIKE clause.
261 @param where_cond - @<where_clause@> clause provided by user.
262
263 @returns pointer to Query_block on success, NULL otherwise.
264*/
266 Table_ident *table_ident,
267 const String *wild, Item *where_cond);
268
269/**
270 Build a substitute query for SHOW INDEX|KEYS|INDEXES
271
272 For command like,
273 @code
274 SHOW {INDEX | INDEXES | KEYS}
275 {FROM | IN} tbl_name
276 [{FROM | IN} db_name]
277 [WHERE expr]
278 @endcode
279
280 We build following,
281 @code
282 SELECT Table,
283 Non_unique,
284 Key_name,
285 Seq_in_index,
286 Column_name,
287 Collation,
288 Cardinality,
289 Sub_part,
290 Packed,
291 Null,
292 Index_type,
293 Comment,
294 Index_comment,
295 Visible
296 FROM
297 (SELECT Database,
298 Table,
299 Non_unique,
300 Key_name,
301 Seq_in_index,
302 Column_name,
303 Collation,
304 Cardinality,
305 Sub_part,
306 Packed,
307 Null,
308 Index_type,
309 Comment,
310 Index_comment,
311 Visible,
312 INDEX_ORDINAL_POSITION,
313 COLUMN_ORDINAL_POSITION
314 FROM information_schema.show_statistics) statistics
315 WHERE Database == '<value>' <-- Default DB or db_name
316 AND
317 Table == 'value' <-- tbl_name
318 AND
319 [ @<where_clause@> ]
320 ORDER BY INDEX_ORDINAL_POSITION, COLUMN_ORDINAL_POSITION
321 @endcode
322
323
324 @param pos - YYLTYPE position of parsing context.
325 @param thd - Current thread.
326 @param table_ident - Database and Table name of table being used.
327 @param where_cond - @<where_clause@> clause provided by user.
328
329 @returns pointer to Query_block on success, NULL otherwise.
330*/
331Query_block *build_show_keys_query(const POS &pos, THD *thd,
332 Table_ident *table_ident, Item *where_cond);
333
334/**
335 Build a substitute query for SHOW TRIGGERS
336
337 For command like,
338 @code
339 SHOW TRIGGERS [{FROM | IN} db_name]
340 [LIKE 'pattern' | WHERE expr]
341 @endcode
342
343 We build following,
344 @code
345 SELECT
346 Trigger,
347 Event,
348 Table,
349 Statement,
350 Timing,
351 Created,
352 sql_mode,
353 Definer,
354 character_set_client,
355 collation_connection,
356 Database_collation AS `Database Collation`
357 FROM
358 (SELECT
359 EVENT_OBJECT_SCHEMA AS `Database`
360 TRIGGER_NAME AS `Trigger`,
361 EVENT_MANIPULATION AS `Event`,
362 EVENT_OBJECT_TABLE AS `Table`,
363 ACTION_STATEMENT AS `Statement`,
364 ACTION_TIMING AS `Timing`,
365 CREATED AS `Created`,
366 SQL_MODE AS `sql_mode`,
367 DEFINER AS `Definer`,
368 CHARACTER_SET_CLIENT AS `character_set_client`,
369 COLLATION_CONNECTION AS `collation_connection`,
370 DATABASE_COLLATION AS `Database_collation`,
371 ACTION_ORDER AS `action_order`
372 FROM information_schema.triggers) triggers
373 WHERE Database == '<value>' <-- Default DB or IN clause
374 AND
375 [ Table LIKE "<value>" | @<where_clause@> ]
376 ORDER BY `Table`, `Event`, `Timing`, `action_order`;
377
378 @endcode
379
380 @param pos - YYLTYPE position of parsing context.
381 @param thd - Current thread.
382 @param wild - The value of LIKE clause.
383 @param where_cond - @<where_clause@> clause provided by user.
384
385 @returns pointer to Query_block on success, NULL otherwise.
386*/
387Query_block *build_show_triggers_query(const POS &pos, THD *thd, String *wild,
388 Item *where_cond);
389
390/**
391 Build a substitute query for SHOW PROCEDURE/FUNCTION STATUS
392
393 For command like,
394 @code
395 SHOW [PROCEDURE|FUNCTION] STATUS
396 [LIKE 'pattern' | WHERE expr]
397 @endcode
398
399 We build following,
400 @code
401 SELECT
402 Db,
403 Name,
404 Type,
405 Definer,
406 Modified,
407 Created,
408 Security_type,
409 Comment,
410 character_set_client,
411 collation_connection,
412 Database_collation AS `Database Collation`
413 FROM
414 (SELECT
415 ROUTINE_SCHEMA AS `Db`,
416 ROUTINE_NAME AS `Name`,
417 ROUTINE_TYPE AS `Type`,
418 DEFINER AS `Definer`,
419 LAST_ALTERED AS `Modified`,
420 CREATED AS `Created`,
421 SECURITY_TYPE AS `Security_type`,
422 ROUTINE_COMMENT AS `Comment`,
423 CHARACTER_SET_CLIENT AS `character_set_client,
424 COLLATION_CONNECTION AS `collation_connection,
425 DATABASE_COLLATION AS `Database Collation`
426 FROM information_schema.routines) routines
427 WHERE Db == '<value>' <-- Default DB or IN clause
428 AND
429 [ Name LIKE "<value>" | @<where_clause@> ]
430 ORDER BY `Db`, `Name`;
431
432 @endcode
433
434 @param pos - YYLTYPE position of parsing context.
435 @param thd - Current thread.
436 @param wild - The value of LIKE clause.
437 @param where_cond - @<where_clause@> clause provided by user.
438
439 @returns pointer to Query_block on success, NULL otherwise.
440*/
441Query_block *build_show_procedures_query(const POS &pos, THD *thd, String *wild,
442 Item *where_cond);
443
444/**
445 Build a substitute query for SHOW EVENTS
446
447 For command like,
448 @code
449 SHOW EVENTS [{FROM | IN} schema_name]
450 [LIKE 'pattern' | WHERE expr]
451 @endcode
452
453 We build following,
454 @code
455 SELECT
456 Db,
457 Name,
458 Definer,
459 Time zone,
460 Type,
461 Execute at,
462 Interval value,
463 Interval field,
464 Starts,
465 Ends,
466 Status,
467 Originator,
468 character_set_client,
469 collation_connection,
470 Database_collation AS Database Collation
471 FROM
472 (SELECT
473 EVENT_SCHEMA AS `Db`,
474 EVENT_NAME AS `Name`,
475 DEFINER AS `Definer`,
476 TIME_ZONE AS `Time zone`,
477 EVENT_TYPE AS `Type`,
478 EXECUTE_AT AS `Execute at`,
479 INTERVAL_VALUE AS `Interval value`,
480 INTERVAL_FIELD AS `Interval field`,
481 STARTS AS `Starts`,
482 ENDS AS `Ends`,
483 STATUS AS `Status`,
484 ORIGINATOR AS `Originator`,
485 CHARACTER_SET_CLIENT AS `character_set_client`,
486 COLLATION_CONNECTION AS `collation_connection`,
487 DATABASE_COLLATION AS `Database Collation`
488 FROM information_schema.events) as events
489 WHERE Db == '<value>' <-- Default DB or IN clause
490 AND
491 [ Name LIKE "<value>" | @<where_clause@> ]
492 ORDER BY `Db`, `Name`;
493
494 @endcode
495
496 @param pos - YYLTYPE position of parsing context.
497 @param thd - Current thread.
498 @param wild - The value of LIKE clause.
499 @param where_cond - @<where_clause@> clause provided by user.
500
501 @returns pointer to Query_block on success, NULL otherwise.
502*/
503Query_block *build_show_events_query(const POS &pos, THD *thd, String *wild,
504 Item *where_cond);
505
506} // namespace info_schema
507} // namespace dd
508
509#endif /* SQL_DD_SHOW_H */
Base class that is used to represent any kind of expression in a relational query.
Definition: item.h:853
This class represents a query block, aka a query specification, which is a query consisting of a SELE...
Definition: sql_lex.h:1156
Using this class is fraught with peril, and you need to be very careful when doing so.
Definition: sql_string.h:168
For each client connection we create a separate thread with THD serving as a thread/connection descri...
Definition: sql_lexer_thd.h:34
Definition: sql_lex.h:294
Query_block * build_show_character_set_query(const POS &pos, THD *thd, const String *wild, Item *where_cond)
Build a substitute query for SHOW CHARSETS.
Definition: show.cc:46
Query_block * build_show_events_query(const POS &pos, THD *thd, String *wild, Item *where_cond)
Build a substitute query for SHOW EVENTS.
Definition: show.cc:1185
Query_block * build_show_keys_query(const POS &pos, THD *thd, Table_ident *table_ident, Item *where_cond)
Build a substitute query for SHOW INDEX|KEYS|INDEXES.
Definition: show.cc:758
Query_block * build_show_triggers_query(const POS &pos, THD *thd, String *wild, Item *where_cond)
Build a substitute query for SHOW TRIGGERS.
Definition: show.cc:922
Query_block * build_show_procedures_query(const POS &pos, THD *thd, String *wild, Item *where_cond)
Build a substitute query for SHOW PROCEDURE/FUNCTION STATUS.
Definition: show.cc:1071
Query_block * build_show_columns_query(const POS &pos, THD *thd, Table_ident *table_ident, const String *wild, Item *where_cond)
Build a substitute query for SHOW COLUMNS/FIELDS OR DESCRIBE.
Definition: show.cc:615
Query_block * build_show_tables_query(const POS &pos, THD *thd, String *wild, Item *where_cond, bool include_status_fields)
Build a substitute query for SHOW TABLES / TABLE STATUS.
Definition: show.cc:497
Query_block * build_show_collation_query(const POS &pos, THD *thd, const String *wild, Item *where_cond)
Build a substitute query for SHOW COLLATION.
Definition: show.cc:161
Query_block * build_show_databases_query(const POS &pos, THD *thd, String *wild, Item *where_cond)
Build a substitute query for SHOW DATABASES.
Definition: show.cc:304
The version of the current data dictionary table definitions.
Definition: dictionary_client.h:43
YYLTYPE POS
Definition: show.h:32
Bison "location" class.
Definition: parse_location.h:43