2016-02-09 11:27:40 +01:00
|
|
|
/* Copyright (c) 2005, 2010, Oracle and/or its affiliates.
|
|
|
|
Copyright (c) 2012, 2016, MariaDB
|
2006-12-31 02:29:11 +01:00
|
|
|
|
|
|
|
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 02110-1301 USA */
|
2005-12-22 06:39:02 +01:00
|
|
|
|
|
|
|
#ifndef SQL_SHOW_H
|
|
|
|
#define SQL_SHOW_H
|
|
|
|
|
2010-03-31 16:05:33 +02:00
|
|
|
#include "sql_list.h" /* List */
|
|
|
|
#include "handler.h" /* enum_schema_tables */
|
|
|
|
#include "table.h" /* enum_schema_table_state */
|
2012-07-17 21:52:08 +04:00
|
|
|
#include "my_apc.h"
|
2010-03-31 16:05:33 +02:00
|
|
|
|
2005-12-22 06:39:02 +01:00
|
|
|
/* Forward declarations */
|
2010-03-31 16:05:33 +02:00
|
|
|
class JOIN;
|
2005-12-22 06:39:02 +01:00
|
|
|
class String;
|
|
|
|
class THD;
|
2010-03-31 16:05:33 +02:00
|
|
|
class sp_name;
|
|
|
|
struct TABLE_LIST;
|
|
|
|
typedef class st_select_lex SELECT_LEX;
|
|
|
|
struct LEX;
|
|
|
|
typedef struct st_mysql_show_var SHOW_VAR;
|
|
|
|
typedef struct st_schema_table ST_SCHEMA_TABLE;
|
|
|
|
struct TABLE;
|
|
|
|
typedef struct system_status_var STATUS_VAR;
|
2005-12-22 06:39:02 +01:00
|
|
|
|
2010-03-31 16:05:33 +02:00
|
|
|
/* Used by handlers to store things in schema tables */
|
|
|
|
#define IS_FILES_FILE_ID 0
|
|
|
|
#define IS_FILES_FILE_NAME 1
|
|
|
|
#define IS_FILES_FILE_TYPE 2
|
|
|
|
#define IS_FILES_TABLESPACE_NAME 3
|
|
|
|
#define IS_FILES_TABLE_CATALOG 4
|
|
|
|
#define IS_FILES_TABLE_SCHEMA 5
|
|
|
|
#define IS_FILES_TABLE_NAME 6
|
|
|
|
#define IS_FILES_LOGFILE_GROUP_NAME 7
|
|
|
|
#define IS_FILES_LOGFILE_GROUP_NUMBER 8
|
|
|
|
#define IS_FILES_ENGINE 9
|
|
|
|
#define IS_FILES_FULLTEXT_KEYS 10
|
|
|
|
#define IS_FILES_DELETED_ROWS 11
|
|
|
|
#define IS_FILES_UPDATE_COUNT 12
|
|
|
|
#define IS_FILES_FREE_EXTENTS 13
|
|
|
|
#define IS_FILES_TOTAL_EXTENTS 14
|
|
|
|
#define IS_FILES_EXTENT_SIZE 15
|
|
|
|
#define IS_FILES_INITIAL_SIZE 16
|
|
|
|
#define IS_FILES_MAXIMUM_SIZE 17
|
|
|
|
#define IS_FILES_AUTOEXTEND_SIZE 18
|
|
|
|
#define IS_FILES_CREATION_TIME 19
|
|
|
|
#define IS_FILES_LAST_UPDATE_TIME 20
|
|
|
|
#define IS_FILES_LAST_ACCESS_TIME 21
|
|
|
|
#define IS_FILES_RECOVER_TIME 22
|
|
|
|
#define IS_FILES_TRANSACTION_COUNTER 23
|
|
|
|
#define IS_FILES_VERSION 24
|
|
|
|
#define IS_FILES_ROW_FORMAT 25
|
|
|
|
#define IS_FILES_TABLE_ROWS 26
|
|
|
|
#define IS_FILES_AVG_ROW_LENGTH 27
|
|
|
|
#define IS_FILES_DATA_LENGTH 28
|
|
|
|
#define IS_FILES_MAX_DATA_LENGTH 29
|
|
|
|
#define IS_FILES_INDEX_LENGTH 30
|
|
|
|
#define IS_FILES_DATA_FREE 31
|
|
|
|
#define IS_FILES_CREATE_TIME 32
|
|
|
|
#define IS_FILES_UPDATE_TIME 33
|
|
|
|
#define IS_FILES_CHECK_TIME 34
|
|
|
|
#define IS_FILES_CHECKSUM 35
|
|
|
|
#define IS_FILES_STATUS 36
|
|
|
|
#define IS_FILES_EXTRA 37
|
|
|
|
|
2014-07-08 19:39:06 +02:00
|
|
|
typedef enum { WITHOUT_DB_NAME, WITH_DB_NAME } enum_with_db_name;
|
|
|
|
int show_create_table(THD *thd, TABLE_LIST *table_list, String *packet,
|
2014-12-08 10:56:08 +04:00
|
|
|
Table_specification_st *create_info_arg,
|
2014-07-08 19:39:06 +02:00
|
|
|
enum_with_db_name with_db_name);
|
2005-12-22 06:39:02 +01:00
|
|
|
|
2006-06-28 14:22:14 +02:00
|
|
|
int copy_event_to_schema_table(THD *thd, TABLE *sch_table, TABLE *event_table);
|
|
|
|
|
2012-08-24 15:29:01 +02:00
|
|
|
bool append_identifier(THD *thd, String *packet, const char *name,
|
2010-03-31 16:05:33 +02:00
|
|
|
uint length);
|
|
|
|
void mysqld_list_fields(THD *thd,TABLE_LIST *table, const char *wild);
|
|
|
|
int mysqld_dump_create_info(THD *thd, TABLE_LIST *table_list, int fd);
|
2016-01-26 16:00:59 +04:00
|
|
|
bool mysqld_show_create_get_fields(THD *thd, TABLE_LIST *table_list,
|
|
|
|
List<Item> *field_list, String *buffer);
|
2010-03-31 16:05:33 +02:00
|
|
|
bool mysqld_show_create(THD *thd, TABLE_LIST *table_list);
|
2016-01-27 12:01:55 +04:00
|
|
|
void mysqld_show_create_db_get_fields(THD *thd, List<Item> *field_list);
|
2014-03-23 15:43:57 +02:00
|
|
|
bool mysqld_show_create_db(THD *thd, LEX_STRING *db_name,
|
|
|
|
LEX_STRING *orig_db_name,
|
2014-12-08 10:56:08 +04:00
|
|
|
const DDL_options_st &options);
|
2010-03-31 16:05:33 +02:00
|
|
|
|
|
|
|
void mysqld_list_processes(THD *thd,const char *user,bool verbose);
|
|
|
|
int mysqld_show_status(THD *thd);
|
|
|
|
int mysqld_show_variables(THD *thd,const char *wild);
|
|
|
|
bool mysqld_show_storage_engines(THD *thd);
|
|
|
|
bool mysqld_show_authors(THD *thd);
|
|
|
|
bool mysqld_show_contributors(THD *thd);
|
|
|
|
bool mysqld_show_privileges(THD *thd);
|
|
|
|
char *make_backup_log_name(char *buff, const char *name, const char* log_ext);
|
2016-04-28 11:10:55 +03:00
|
|
|
uint calc_sum_of_all_status(STATUS_VAR *to);
|
2010-03-31 16:05:33 +02:00
|
|
|
void append_definer(THD *thd, String *buffer, const LEX_STRING *definer_user,
|
|
|
|
const LEX_STRING *definer_host);
|
|
|
|
int add_status_vars(SHOW_VAR *list);
|
|
|
|
void remove_status_vars(SHOW_VAR *list);
|
|
|
|
void init_status_vars();
|
|
|
|
void free_status_vars();
|
|
|
|
void reset_status_vars();
|
|
|
|
bool show_create_trigger(THD *thd, const sp_name *trg_name);
|
|
|
|
void view_store_options(THD *thd, TABLE_LIST *table, String *buff);
|
|
|
|
|
|
|
|
void init_fill_schema_files_row(TABLE* table);
|
|
|
|
bool schema_table_store_record(THD *thd, TABLE *table);
|
|
|
|
void initialize_information_schema_acl();
|
2015-08-11 11:18:38 +04:00
|
|
|
COND *make_cond_for_info_schema(THD *thd, COND *cond, TABLE_LIST *table);
|
2010-03-31 16:05:33 +02:00
|
|
|
|
2016-02-20 22:26:48 +01:00
|
|
|
ST_SCHEMA_TABLE *find_schema_table(THD *thd, const char* table_name, bool *in_plugin);
|
|
|
|
static inline ST_SCHEMA_TABLE *find_schema_table(THD *thd, const char* table_name)
|
|
|
|
{ bool unused; return find_schema_table(thd, table_name, &unused); }
|
|
|
|
|
2010-03-31 16:05:33 +02:00
|
|
|
ST_SCHEMA_TABLE *get_schema_table(enum enum_schema_tables schema_table_idx);
|
|
|
|
int make_schema_select(THD *thd, SELECT_LEX *sel,
|
2014-08-25 19:08:01 +02:00
|
|
|
ST_SCHEMA_TABLE *schema_table);
|
2010-03-31 16:05:33 +02:00
|
|
|
int mysql_schema_table(THD *thd, LEX *lex, TABLE_LIST *table_list);
|
|
|
|
bool get_schema_tables_result(JOIN *join,
|
|
|
|
enum enum_schema_table_state executed_place);
|
|
|
|
enum enum_schema_tables get_schema_table_idx(ST_SCHEMA_TABLE *schema_table);
|
2014-08-25 19:08:01 +02:00
|
|
|
TABLE *create_schema_table(THD *thd, TABLE_LIST *table_list);
|
2010-03-31 16:05:33 +02:00
|
|
|
|
2016-04-15 20:47:45 +02:00
|
|
|
const char* get_one_variable(THD *thd, const SHOW_VAR *variable,
|
|
|
|
enum_var_type value_type, SHOW_TYPE show_type,
|
|
|
|
system_status_var *status_var,
|
|
|
|
const CHARSET_INFO **charset, char *buff,
|
|
|
|
size_t *length);
|
|
|
|
|
2010-03-31 16:05:33 +02:00
|
|
|
/* These functions were under INNODB_COMPATIBILITY_HOOKS */
|
|
|
|
int get_quote_char_for_identifier(THD *thd, const char *name, uint length);
|
2013-09-13 20:14:56 +04:00
|
|
|
THD *find_thread_by_id(longlong id, bool query_id= false);
|
2010-03-31 16:05:33 +02:00
|
|
|
|
2012-07-17 21:52:08 +04:00
|
|
|
class select_result_explain_buffer;
|
|
|
|
/*
|
|
|
|
SHOW EXPLAIN request object.
|
|
|
|
*/
|
|
|
|
|
|
|
|
class Show_explain_request : public Apc_target::Apc_call
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
THD *target_thd; /* thd that we're running SHOW EXPLAIN for */
|
|
|
|
THD *request_thd; /* thd that run SHOW EXPLAIN command */
|
|
|
|
|
|
|
|
/* If true, there was some error when producing EXPLAIN output. */
|
|
|
|
bool failed_to_produce;
|
|
|
|
|
|
|
|
/* SHOW EXPLAIN will be stored here */
|
|
|
|
select_result_explain_buffer *explain_buf;
|
|
|
|
|
|
|
|
/* Query that we've got SHOW EXPLAIN for */
|
|
|
|
String query_str;
|
|
|
|
|
|
|
|
/* Overloaded virtual function */
|
|
|
|
void call_in_target_thread();
|
|
|
|
};
|
2010-03-31 16:05:33 +02:00
|
|
|
|
2014-06-25 16:46:42 +04:00
|
|
|
/**
|
|
|
|
Condition pushdown used for INFORMATION_SCHEMA / SHOW queries.
|
|
|
|
This structure is to implement an optimization when
|
|
|
|
accessing data dictionary data in the INFORMATION_SCHEMA
|
|
|
|
or SHOW commands.
|
|
|
|
When the query contain a TABLE_SCHEMA or TABLE_NAME clause,
|
|
|
|
narrow the search for data based on the constraints given.
|
|
|
|
*/
|
2014-06-24 19:41:43 +04:00
|
|
|
typedef struct st_lookup_field_values
|
|
|
|
{
|
2014-06-25 16:46:42 +04:00
|
|
|
/**
|
|
|
|
Value of a TABLE_SCHEMA clause.
|
|
|
|
Note that this value length may exceed @c NAME_LEN.
|
|
|
|
@sa wild_db_value
|
|
|
|
*/
|
|
|
|
LEX_STRING db_value;
|
|
|
|
/**
|
|
|
|
Value of a TABLE_NAME clause.
|
|
|
|
Note that this value length may exceed @c NAME_LEN.
|
|
|
|
@sa wild_table_value
|
|
|
|
*/
|
|
|
|
LEX_STRING table_value;
|
|
|
|
/**
|
|
|
|
True when @c db_value is a LIKE clause,
|
|
|
|
false when @c db_value is an '=' clause.
|
|
|
|
*/
|
|
|
|
bool wild_db_value;
|
|
|
|
/**
|
|
|
|
True when @c table_value is a LIKE clause,
|
|
|
|
false when @c table_value is an '=' clause.
|
|
|
|
*/
|
|
|
|
bool wild_table_value;
|
|
|
|
} LOOKUP_FIELD_VALUES;
|
2014-06-24 19:41:43 +04:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
INFORMATION_SCHEMA: Execution plan for get_all_tables() call
|
|
|
|
*/
|
|
|
|
|
|
|
|
class IS_table_read_plan : public Sql_alloc
|
|
|
|
{
|
|
|
|
public:
|
2014-09-04 01:12:49 +04:00
|
|
|
IS_table_read_plan() : no_rows(false), trivial_show_command(FALSE) {}
|
2014-06-24 19:41:43 +04:00
|
|
|
|
|
|
|
bool no_rows;
|
2014-09-04 01:12:49 +04:00
|
|
|
/*
|
|
|
|
For EXPLAIN only: For SHOW KEYS and SHOW COLUMNS, we know which
|
|
|
|
db_name.table_name will be read, however for some reason we don't
|
|
|
|
set the fields in this->lookup_field_vals.
|
|
|
|
In order to not have JOIN::save_explain_data() walking over uninitialized
|
|
|
|
data, we set trivial_show_command=true.
|
|
|
|
*/
|
|
|
|
bool trivial_show_command;
|
2014-06-24 19:41:43 +04:00
|
|
|
|
|
|
|
LOOKUP_FIELD_VALUES lookup_field_vals;
|
|
|
|
Item *partial_cond;
|
|
|
|
|
|
|
|
bool has_db_lookup_value()
|
|
|
|
{
|
|
|
|
return (lookup_field_vals.db_value.length &&
|
|
|
|
!lookup_field_vals.wild_db_value);
|
|
|
|
}
|
|
|
|
bool has_table_lookup_value()
|
|
|
|
{
|
|
|
|
return (lookup_field_vals.table_value.length &&
|
|
|
|
!lookup_field_vals.wild_table_value);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
bool optimize_schema_tables_reads(JOIN *join);
|
|
|
|
|
2012-09-27 13:18:07 +05:00
|
|
|
/* Handle the ignored database directories list for SHOW/I_S. */
|
|
|
|
bool ignore_db_dirs_init();
|
|
|
|
void ignore_db_dirs_free();
|
|
|
|
void ignore_db_dirs_reset();
|
|
|
|
bool ignore_db_dirs_process_additions();
|
|
|
|
bool push_ignored_db_dir(char *path);
|
|
|
|
extern char *opt_ignore_db_dirs;
|
|
|
|
|
2005-12-22 06:39:02 +01:00
|
|
|
#endif /* SQL_SHOW_H */
|