/* Copyright (C) 2000-2003 MySQL AB 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ /** @file @details Mostly this file is used in the server. But a little part of it is used in mysqlbinlog too (definition of SELECT_DISTINCT and others). The consequence is that 90% of the file is wrapped in \#ifndef DRIZZLE_CLIENT, except the part which must be in the server and in the client. @TODO Name this file better. "priv" could mean private, privileged, privileges. @TODO Get rid of the DRIZZLE_CLIENT and DRIZZLE_SERVER conditionals */ #ifndef DRIZZLE_SERVER_SERVER_INCLUDES_H #define DRIZZLE_SERVER_SERVER_INCLUDES_H /* Some forward declarations just for the server */ class Comp_creator; typedef Comp_creator* (*chooser_compare_func_creator)(bool invert); /** * Contains all headers, definitions, and declarations common to * the server and the plugin infrastructure, and not the client */ #include /* Range optimization API/library */ #include /* Simple error injection (crash) module */ #include /* API for connecting, logging in to a drizzled server */ #include /* Routines for dropping, repairing, checking schema tables */ #include /* sql_db.cc */ int mysql_create_db(THD *thd, char *db, HA_CREATE_INFO *create, bool silent); bool mysql_alter_db(THD *thd, const char *db, HA_CREATE_INFO *create); bool mysql_rm_db(THD *thd,char *db,bool if_exists, bool silent); bool mysql_change_db(THD *thd, const LEX_STRING *new_db_name, bool force_switch); bool mysql_opt_change_db(THD *thd, const LEX_STRING *new_db_name, LEX_STRING *saved_db_name, bool force_switch, bool *cur_db_changed); /* sql_repl.cc */ void write_bin_log(THD *thd, bool clear_error, char const *query, ulong query_length); void mysql_binlog_send(THD* thd, char* log_ident, my_off_t pos, ushort flags); void mysql_client_binlog_statement(THD *thd); /* sql_rename.cc */ bool mysql_rename_tables(THD *thd, TableList *table_list, bool silent); bool do_rename(THD *thd, TableList *ren_table, char *new_db, char *new_table_name, char *new_table_alias, bool skip_error); /* sql_parse.cc */ void mysql_parse(THD *thd, const char *inBuf, uint length, const char ** semicolon); bool mysql_test_parse_for_slave(THD *thd,char *inBuf,uint length); bool is_update_query(enum enum_sql_command command); bool alloc_query(THD *thd, const char *packet, uint packet_length); void mysql_reset_thd_for_next_command(THD *thd); void create_select_for_variable(const char *var_name); void mysql_init_multi_delete(LEX *lex); bool multi_delete_set_locks_and_link_aux_tables(LEX *lex); void init_update_queries(void); bool do_command(THD *thd); bool dispatch_command(enum enum_server_command command, THD *thd, char* packet, uint packet_length); void log_slow_statement(THD *thd); bool append_file_to_dir(THD *thd, const char **filename_ptr, const char *table_name); bool reload_cache(THD *thd, ulong options, TableList *tables, bool *write_to_binlog); bool check_simple_select(); /* @TODO */ void mysql_init_select(LEX *lex); bool mysql_new_select(LEX *lex, bool move_down); void init_max_user_conn(void); void free_max_user_conn(void); pthread_handler_t handle_bootstrap(void *arg); int mysql_execute_command(THD *thd); bool check_dup(const char *db, const char *name, TableList *tables); bool check_table_access(THD *thd, ulong want_access, TableList *tables, bool no_errors, bool any_combination_of_privileges_will_do, uint number); /* General routine to change field->ptr of a NULL-terminated array of Field objects. Useful when needed to call val_int, val_str or similar and the field data is not in table->record[0] but in some other structure. set_key_field_ptr changes all fields of an index using a key_info object. All methods presume that there is at least one field to change. */ void set_field_ptr(Field **ptr, const uchar *new_buf, const uchar *old_buf); void set_key_field_ptr(KEY *key_info, const uchar *new_buf, const uchar *old_buf); /* */ /* sql_base.cc */ void table_cache_free(void); bool table_cache_init(void); bool table_def_init(void); void table_def_free(void); void assign_new_table_id(TABLE_SHARE *share); uint cached_open_tables(void); uint cached_table_definitions(void); /* drizzled.cc */ void kill_mysql(void); void close_connection(THD *thd, uint errcode, bool lock); /* sql_select.cc */ Table *create_virtual_tmp_table(THD *thd, List &field_list); /* handler.cc */ bool mysql_xa_recover(THD *thd); SORT_FIELD * make_unireg_sortorder(order_st *order, uint *length, SORT_FIELD *sortorder); int setup_order(THD *thd, Item **ref_pointer_array, TableList *tables, List &fields, List &all_fields, order_st *order); int setup_group(THD *thd, Item **ref_pointer_array, TableList *tables, List &fields, List &all_fields, order_st *order, bool *hidden_group_fields); bool fix_inner_refs(THD *thd, List &all_fields, SELECT_LEX *select, Item **ref_pointer_array); bool handle_select(THD *thd, LEX *lex, select_result *result, ulong setup_tables_done_option); bool mysql_select(THD *thd, Item ***rref_pointer_array, TableList *tables, uint wild_num, List &list, COND *conds, uint og_num, order_st *order, order_st *group, Item *having, order_st *proc_param, uint64_t select_type, select_result *result, SELECT_LEX_UNIT *unit, SELECT_LEX *select_lex); void free_underlaid_joins(THD *thd, SELECT_LEX *select); bool mysql_explain_union(THD *thd, SELECT_LEX_UNIT *unit, select_result *result); int mysql_explain_select(THD *thd, SELECT_LEX *sl, char const *type, select_result *result); bool mysql_union(THD *thd, LEX *lex, select_result *result, SELECT_LEX_UNIT *unit, ulong setup_tables_done_option); bool mysql_handle_derived(LEX *lex, bool (*processor)(THD *thd, LEX *lex, TableList *table)); bool mysql_derived_prepare(THD *thd, LEX *lex, TableList *t); bool mysql_derived_filling(THD *thd, LEX *lex, TableList *t); Field *create_tmp_field(THD *thd, Table *table,Item *item, Item::Type type, Item ***copy_func, Field **from_field, Field **def_field, bool group, bool modify_item, bool table_cant_handle_bit_fields, bool make_copy_field, uint convert_blob_length); void sp_prepare_create_field(THD *thd, Create_field *sql_field); int prepare_create_field(Create_field *sql_field, uint *blob_columns, int *timestamps, int *timestamps_with_niladic, int64_t table_flags); bool mysql_create_table(THD *thd,const char *db, const char *table_name, HA_CREATE_INFO *create_info, Alter_info *alter_info, bool tmp_table, uint select_field_count); bool mysql_create_table_no_lock(THD *thd, const char *db, const char *table_name, HA_CREATE_INFO *create_info, Alter_info *alter_info, bool tmp_table, uint select_field_count); bool mysql_alter_table(THD *thd, char *new_db, char *new_name, HA_CREATE_INFO *create_info, TableList *table_list, Alter_info *alter_info, uint order_num, order_st *order, bool ignore); bool mysql_recreate_table(THD *thd, TableList *table_list); bool mysql_create_like_table(THD *thd, TableList *table, TableList *src_table, HA_CREATE_INFO *create_info); bool mysql_rename_table(handlerton *base, const char *old_db, const char * old_name, const char *new_db, const char * new_name, uint flags); bool mysql_prepare_update(THD *thd, TableList *table_list, Item **conds, uint order_num, order_st *order); int mysql_update(THD *thd,TableList *tables,List &fields, List &values,COND *conds, uint order_num, order_st *order, ha_rows limit, enum enum_duplicates handle_duplicates, bool ignore); bool mysql_multi_update(THD *thd, TableList *table_list, List *fields, List *values, COND *conds, uint64_t options, enum enum_duplicates handle_duplicates, bool ignore, SELECT_LEX_UNIT *unit, SELECT_LEX *select_lex); bool mysql_prepare_insert(THD *thd, TableList *table_list, Table *table, List &fields, List_item *values, List &update_fields, List &update_values, enum_duplicates duplic, COND **where, bool select_insert, bool check_fields, bool abort_on_warning); bool mysql_insert(THD *thd,TableList *table,List &fields, List &values, List &update_fields, List &update_values, enum_duplicates flag, bool ignore); int check_that_all_fields_are_given_values(THD *thd, Table *entry, TableList *table_list); void prepare_triggers_for_insert_stmt(Table *table); int mysql_prepare_delete(THD *thd, TableList *table_list, Item **conds); bool mysql_delete(THD *thd, TableList *table_list, COND *conds, SQL_LIST *order, ha_rows rows, uint64_t options, bool reset_auto_increment); bool mysql_truncate(THD *thd, TableList *table_list, bool dont_send_ok); uint create_table_def_key(THD *thd, char *key, TableList *table_list, bool tmp_table); TABLE_SHARE *get_table_share(THD *thd, TableList *table_list, char *key, uint key_length, uint db_flags, int *error); void release_table_share(TABLE_SHARE *share, enum release_type type); TABLE_SHARE *get_cached_table_share(const char *db, const char *table_name); Table *open_ltable(THD *thd, TableList *table_list, thr_lock_type update, uint lock_flags); Table *open_table(THD *thd, TableList *table_list, bool *refresh, uint flags); bool name_lock_locked_table(THD *thd, TableList *tables); bool reopen_name_locked_table(THD* thd, TableList* table_list, bool link_in); Table *table_cache_insert_placeholder(THD *thd, const char *key, uint key_length); bool lock_table_name_if_not_cached(THD *thd, const char *db, const char *table_name, Table **table); Table *find_locked_table(THD *thd, const char *db,const char *table_name); void detach_merge_children(Table *table, bool clear_refs); bool fix_merge_after_open(TableList *old_child_list, TableList **old_last, TableList *new_child_list, TableList **new_last); bool reopen_table(Table *table); bool reopen_tables(THD *thd,bool get_locks,bool in_refresh); void close_data_files_and_morph_locks(THD *thd, const char *db, const char *table_name); void close_handle_and_leave_table_as_lock(Table *table); bool open_new_frm(THD *thd, TABLE_SHARE *share, const char *alias, uint db_stat, uint prgflag, uint ha_open_flags, Table *outparam, TableList *table_desc, MEM_ROOT *mem_root); bool wait_for_tables(THD *thd); bool table_is_used(Table *table, bool wait_for_name_lock); Table *drop_locked_tables(THD *thd,const char *db, const char *table_name); void abort_locked_tables(THD *thd,const char *db, const char *table_name); void execute_init_command(THD *thd, sys_var_str *init_command_var, rw_lock_t *var_mutex); extern Field *not_found_field; extern Field *view_ref_found; enum find_item_error_report_type {REPORT_ALL_ERRORS, REPORT_EXCEPT_NOT_FOUND, IGNORE_ERRORS, REPORT_EXCEPT_NON_UNIQUE, IGNORE_EXCEPT_NON_UNIQUE}; Field * find_field_in_tables(THD *thd, Item_ident *item, TableList *first_table, TableList *last_table, Item **ref, find_item_error_report_type report_error, bool check_privileges, bool register_tree_change); Field * find_field_in_table_ref(THD *thd, TableList *table_list, const char *name, uint length, const char *item_name, const char *db_name, const char *table_name, Item **ref, bool check_privileges, bool allow_rowid, uint *cached_field_index_ptr, bool register_tree_change, TableList **actual_table); Field * find_field_in_table(THD *thd, Table *table, const char *name, uint length, bool allow_rowid, uint *cached_field_index_ptr); Field * find_field_in_table_sef(Table *table, const char *name); /* sql_do.cc */ bool mysql_do(THD *thd, List &values); /* sql_analyse.h */ bool append_escaped(String *to_str, String *from_str); #include /* information schema */ extern LEX_STRING INFORMATION_SCHEMA_NAME; /* log tables */ extern LEX_STRING DRIZZLE_SCHEMA_NAME; extern LEX_STRING GENERAL_LOG_NAME; extern LEX_STRING SLOW_LOG_NAME; extern const LEX_STRING partition_keywords[]; ST_SCHEMA_TABLE *find_schema_table(THD *thd, const char* table_name); ST_SCHEMA_TABLE *get_schema_table(enum enum_schema_tables schema_table_idx); int prepare_schema_table(THD *thd, LEX *lex, Table_ident *table_ident, enum enum_schema_tables schema_table_idx); int make_schema_select(THD *thd, SELECT_LEX *sel, enum enum_schema_tables schema_table_idx); int mysql_schema_table(THD *thd, LEX *lex, TableList *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); #define is_schema_db(X) \ !my_strcasecmp(system_charset_info, INFORMATION_SCHEMA_NAME.str, (X)) /* sql_handler.cc */ bool mysql_ha_open(THD *thd, TableList *tables, bool reopen); bool mysql_ha_close(THD *thd, TableList *tables); bool mysql_ha_read(THD *, TableList *,enum enum_ha_read_modes,char *, List *,enum ha_rkey_function,Item *,ha_rows,ha_rows); void mysql_ha_flush(THD *thd); void mysql_ha_rm_tables(THD *thd, TableList *tables, bool is_locked); void mysql_ha_cleanup(THD *thd); /* sql_base.cc */ #define TMP_TABLE_KEY_EXTRA 8 void set_item_name(Item *item,char *pos,uint length); bool add_field_to_list(THD *thd, LEX_STRING *field_name, enum enum_field_types type, char *length, char *decimal, uint type_modifier, enum column_format_type column_format, Item *default_value, Item *on_update_value, LEX_STRING *comment, char *change, List *interval_list, const CHARSET_INFO * const cs); Create_field * new_create_field(THD *thd, char *field_name, enum_field_types type, char *length, char *decimals, uint type_modifier, Item *default_value, Item *on_update_value, LEX_STRING *comment, char *change, List *interval_list, CHARSET_INFO *cs); void store_position_for_column(const char *name); bool add_to_list(THD *thd, SQL_LIST &list,Item *group,bool asc); bool push_new_name_resolution_context(THD *thd, TableList *left_op, TableList *right_op); void add_join_on(TableList *b,Item *expr); void add_join_natural(TableList *a,TableList *b,List *using_fields, SELECT_LEX *lex); bool add_proc_to_list(THD *thd, Item *item); void unlink_open_table(THD *thd, Table *find, bool unlock); void drop_open_table(THD *thd, Table *table, const char *db_name, const char *table_name); void update_non_unique_table_error(TableList *update, const char *operation, TableList *duplicate); SQL_SELECT *make_select(Table *head, table_map const_tables, table_map read_tables, COND *conds, bool allow_null_cond, int *error); extern Item **not_found_item; /* A set of constants used for checking non aggregated fields and sum functions mixture in the ONLY_FULL_GROUP_BY_MODE. */ #define NON_AGG_FIELD_USED 1 #define SUM_FUNC_USED 2 /* This enumeration type is used only by the function find_item_in_list to return the info on how an item has been resolved against a list of possibly aliased items. The item can be resolved: - against an alias name of the list's element (RESOLVED_AGAINST_ALIAS) - against non-aliased field name of the list (RESOLVED_WITH_NO_ALIAS) - against an aliased field name of the list (RESOLVED_BEHIND_ALIAS) - ignoring the alias name in cases when SQL requires to ignore aliases (e.g. when the resolved field reference contains a table name or when the resolved item is an expression) (RESOLVED_IGNORING_ALIAS) */ enum enum_resolution_type { NOT_RESOLVED=0, RESOLVED_IGNORING_ALIAS, RESOLVED_BEHIND_ALIAS, RESOLVED_WITH_NO_ALIAS, RESOLVED_AGAINST_ALIAS }; Item ** find_item_in_list(Item *item, List &items, uint *counter, find_item_error_report_type report_error, enum_resolution_type *resolution); bool get_key_map_from_key_list(key_map *map, Table *table, List *index_list); bool insert_fields(THD *thd, Name_resolution_context *context, const char *db_name, const char *table_name, List_iterator *it, bool any_privileges); bool setup_tables(THD *thd, Name_resolution_context *context, List *from_clause, TableList *tables, TableList **leaves, bool select_insert); bool setup_tables_and_check_access(THD *thd, Name_resolution_context *context, List *from_clause, TableList *tables, TableList **leaves, bool select_insert); int setup_wild(THD *thd, TableList *tables, List &fields, List *sum_func_list, uint wild_num); bool setup_fields(THD *thd, Item** ref_pointer_array, List &item, enum_mark_columns mark_used_columns, List *sum_func_list, bool allow_sum_func); inline bool setup_fields_with_no_wrap(THD *thd, Item **ref_pointer_array, List &item, enum_mark_columns mark_used_columns, List *sum_func_list, bool allow_sum_func) { bool res; res= setup_fields(thd, ref_pointer_array, item, mark_used_columns, sum_func_list, allow_sum_func); return res; } int setup_conds(THD *thd, TableList *tables, TableList *leaves, COND **conds); int setup_ftfuncs(SELECT_LEX* select); int init_ftfuncs(THD *thd, SELECT_LEX* select, bool no_order); void wait_for_condition(THD *thd, pthread_mutex_t *mutex, pthread_cond_t *cond); int open_tables(THD *thd, TableList **tables, uint *counter, uint flags); /* open_and_lock_tables with optional derived handling */ int open_and_lock_tables_derived(THD *thd, TableList *tables, bool derived); /* simple open_and_lock_tables without derived handling */ inline int simple_open_n_lock_tables(THD *thd, TableList *tables) { return open_and_lock_tables_derived(thd, tables, false); } /* open_and_lock_tables with derived handling */ inline int open_and_lock_tables(THD *thd, TableList *tables) { return open_and_lock_tables_derived(thd, tables, true); } /* simple open_and_lock_tables without derived handling for single table */ Table *open_n_lock_single_table(THD *thd, TableList *table_l, thr_lock_type lock_type); bool open_normal_and_derived_tables(THD *thd, TableList *tables, uint flags); int lock_tables(THD *thd, TableList *tables, uint counter, bool *need_reopen); int decide_logging_format(THD *thd, TableList *tables); Table *open_temporary_table(THD *thd, const char *path, const char *db, const char *table_name, bool link_in_list, open_table_mode open_mode); bool rm_temporary_table(handlerton *base, char *path, bool frm_only); void free_io_cache(Table *entry); void intern_close_table(Table *entry); bool close_thread_table(THD *thd, Table **table_ptr); void close_temporary_tables(THD *thd); void close_tables_for_reopen(THD *thd, TableList **tables); TableList *find_table_in_list(TableList *table, TableList *TableList::*link, const char *db_name, const char *table_name); TableList *unique_table(THD *thd, TableList *table, TableList *table_list, bool check_alias); Table *find_temporary_table(THD *thd, const char *db, const char *table_name); Table *find_temporary_table(THD *thd, TableList *table_list); int drop_temporary_table(THD *thd, TableList *table_list); void close_temporary_table(THD *thd, Table *table, bool free_share, bool delete_table); void close_temporary(Table *table, bool free_share, bool delete_table); bool rename_temporary_table(THD* thd, Table *table, const char *new_db, const char *table_name); void remove_db_from_cache(const char *db); void flush_tables(); bool is_equal(const LEX_STRING *a, const LEX_STRING *b); char *make_default_log_name(char *buff,const char* log_ext); /* bits for last argument to remove_table_from_cache() */ #define RTFC_NO_FLAG 0x0000 #define RTFC_OWNED_BY_THD_FLAG 0x0001 #define RTFC_WAIT_OTHER_THREAD_FLAG 0x0002 #define RTFC_CHECK_KILLED_FLAG 0x0004 bool remove_table_from_cache(THD *thd, const char *db, const char *table, uint flags); #define NORMAL_PART_NAME 0 #define TEMP_PART_NAME 1 #define RENAMED_PART_NAME 2 void mem_alloc_error(size_t size); #define WFRM_WRITE_SHADOW 1 #define WFRM_INSTALL_SHADOW 2 #define WFRM_PACK_FRM 4 #define WFRM_KEEP_SHARE 8 bool close_cached_tables(THD *thd, TableList *tables, bool have_lock, bool wait_for_refresh, bool wait_for_placeholders); bool close_cached_connection_tables(THD *thd, bool wait_for_refresh, LEX_STRING *connect_string, bool have_lock= false); void copy_field_from_tmp_record(Field *field,int offset); bool fill_record(THD * thd, List &fields, List &values, bool ignore_errors); bool fill_record(THD *thd, Field **field, List &values, bool ignore_errors); OPEN_TableList *list_open_tables(THD *thd, const char *db, const char *wild); inline TableList *find_table_in_global_list(TableList *table, const char *db_name, const char *table_name) { return find_table_in_list(table, &TableList::next_global, db_name, table_name); } inline TableList *find_table_in_local_list(TableList *table, const char *db_name, const char *table_name) { return find_table_in_list(table, &TableList::next_local, db_name, table_name); } /* sql_calc.cc */ bool eval_const_cond(COND *cond); /* sql_load.cc */ int mysql_load(THD *thd, sql_exchange *ex, TableList *table_list, List &fields_vars, List &set_fields, List &set_values_list, enum enum_duplicates handle_duplicates, bool ignore, bool local_file); int write_record(THD *thd, Table *table, COPY_INFO *info); /* sql_test.cc */ void print_where(COND *cond,const char *info, enum_query_type query_type); void print_cached_tables(void); void TEST_filesort(SORT_FIELD *sortorder,uint s_length); void print_plan(JOIN* join,uint idx, double record_count, double read_time, double current_read_time, const char *info); void print_keyuse_array(DYNAMIC_ARRAY *keyuse_array); void dump_TableList_graph(SELECT_LEX *select_lex, TableList* tl); void mysql_print_status(); /* key.cc */ int find_ref_key(KEY *key, uint key_count, uchar *record, Field *field, uint *key_length, uint *keypart); void key_copy(uchar *to_key, uchar *from_record, KEY *key_info, uint key_length); void key_restore(uchar *to_record, uchar *from_key, KEY *key_info, uint16_t key_length); void key_zero_nulls(uchar *tuple, KEY *key_info); bool key_cmp_if_same(Table *form,const uchar *key,uint index,uint key_length); void key_unpack(String *to,Table *form,uint index); bool is_key_used(Table *table, uint idx, const MY_BITMAP *fields); int key_cmp(KEY_PART_INFO *key_part, const uchar *key, uint key_length); extern "C" int key_rec_cmp(void *key_info, uchar *a, uchar *b); bool init_errmessage(void); File open_binlog(IO_CACHE *log, const char *log_file_name, const char **errmsg); /* mysqld.cc */ extern void MYSQLerror(const char*); void refresh_status(THD *thd); bool mysql_rm_tmp_tables(void); void handle_connection_in_main_thread(THD *thd); void create_thread_to_handle_connection(THD *thd); void unlink_thd(THD *thd); bool one_thread_per_connection_end(THD *thd, bool put_in_cache); void flush_thread_cache(); /* item_func.cc */ extern bool check_reserved_words(LEX_STRING *name); extern enum_field_types agg_field_type(Item **items, uint nitems); /* strfunc.cc */ uint64_t find_set(TYPELIB *lib, const char *x, uint length, const CHARSET_INFO * const cs, char **err_pos, uint *err_len, bool *set_warning); uint find_type(const TYPELIB *lib, const char *find, uint length, bool part_match); uint find_type2(const TYPELIB *lib, const char *find, uint length, const CHARSET_INFO *cs); void unhex_type2(TYPELIB *lib); uint check_word(TYPELIB *lib, const char *val, const char *end, const char **end_of_word); int find_string_in_array(LEX_STRING * const haystack, LEX_STRING * const needle, const CHARSET_INFO * const cs); bool is_keyword(const char *name, uint len); #define MY_DB_OPT_FILE "db.opt" bool my_database_names_init(void); void my_database_names_free(void); bool check_db_dir_existence(const char *db_name); bool load_db_opt(THD *thd, const char *path, HA_CREATE_INFO *create); bool load_db_opt_by_name(THD *thd, const char *db_name, HA_CREATE_INFO *db_create_info); const CHARSET_INFO *get_default_db_collation(THD *thd, const char *db_name); bool my_dbopt_init(void); void my_dbopt_cleanup(void); extern int creating_database; // How many database locks are made extern int creating_table; // How many mysql_create_table() are running /* External variables */ extern time_t server_start_time, flush_status_time; extern char *opt_mysql_tmpdir, mysql_charsets_dir[]; #define mysql_tmpdir (my_tmpdir(&mysql_tmpdir_list)) extern MY_TMPDIR mysql_tmpdir_list; extern const LEX_STRING command_name[]; extern const char *first_keyword, *my_localhost, *delayed_user, *binary_keyword; extern const char *myisam_recover_options_str; extern const char *in_left_expr_name, *in_additional_cond, *in_having_cond; extern const char * const TRG_EXT; extern const char * const TRN_EXT; extern Eq_creator eq_creator; extern Ne_creator ne_creator; extern Gt_creator gt_creator; extern Lt_creator lt_creator; extern Ge_creator ge_creator; extern Le_creator le_creator; extern char language[FN_REFLEN]; extern char glob_hostname[FN_REFLEN], mysql_home[FN_REFLEN]; extern char pidfile_name[FN_REFLEN], system_time_zone[30], *opt_init_file; extern char log_error_file[FN_REFLEN], *opt_tc_log_file; extern const double log_10[309]; extern uint64_t log_10_int[20]; extern uint64_t keybuff_size; extern uint64_t thd_startup_options; extern ulong thread_id; extern ulong binlog_cache_use, binlog_cache_disk_use; extern ulong aborted_threads,aborted_connects; extern ulong slave_open_temp_tables; extern ulong slow_launch_threads, slow_launch_time; extern ulong table_cache_size, table_def_size; extern ulong max_connections,max_connect_errors, connect_timeout; extern bool slave_allow_batching; extern ulong slave_net_timeout, slave_trans_retries; extern uint max_user_connections; extern ulong what_to_log,flush_time; extern ulong query_buff_size; extern ulong binlog_cache_size, max_binlog_cache_size, open_files_limit; extern ulong max_binlog_size, max_relay_log_size; extern ulong opt_binlog_rows_event_max_size; extern ulong rpl_recovery_rank, thread_cache_size, thread_pool_size; extern ulong back_log; extern ulong current_pid; extern ulong expire_logs_days, sync_binlog_period, sync_binlog_counter; extern ulong opt_tc_log_size, tc_log_max_pages_used, tc_log_page_size; extern ulong tc_log_page_waits; extern bool relay_log_purge; extern bool opt_innodb_safe_binlog, opt_innodb; extern uint test_flags,select_errors,ha_open_options; extern uint protocol_version, mysqld_port, dropping_tables; extern uint delay_key_write_options; extern bool opt_endinfo, using_udf_functions; extern bool locked_in_memory; extern bool opt_using_transactions; extern bool using_update_log, server_id_supplied; extern bool opt_update_log, opt_bin_log, opt_error_log; extern bool opt_log; extern bool opt_slow_log; extern ulong log_output_options; extern bool opt_log_queries_not_using_indexes; extern bool opt_character_set_client_handshake; extern bool volatile abort_loop, shutdown_in_progress; extern uint volatile thread_count, thread_running, global_read_lock; extern uint connection_count; extern bool opt_sql_bin_update; extern bool opt_safe_user_create; extern bool opt_no_mix_types; extern bool opt_safe_show_db, opt_myisam_use_mmap; extern bool opt_local_infile; extern bool opt_slave_compressed_protocol; extern bool use_temp_pool; extern ulong slave_exec_mode_options; extern bool opt_readonly; extern bool opt_sync_frm; extern bool opt_secure_auth; extern char* opt_secure_file_priv; extern bool opt_log_slow_admin_statements; extern bool opt_log_slow_slave_statements; extern bool opt_noacl; extern bool opt_old_style_user_limits; extern uint opt_crash_binlog_innodb; extern char *default_tz_name; extern char *opt_logname, *opt_slow_logname; extern const char *log_output_str; extern DRIZZLE_BIN_LOG mysql_bin_log; extern LOGGER logger; extern TableList general_log, slow_log; extern FILE *stderror_file; extern pthread_key(MEM_ROOT**,THR_MALLOC); extern pthread_mutex_t LOCK_mysql_create_db,LOCK_open, LOCK_lock_db, LOCK_thread_count,LOCK_user_locks, LOCK_status, LOCK_error_log, LOCK_uuid_generator, LOCK_crypt, LOCK_timezone, LOCK_slave_list, LOCK_active_mi, LOCK_global_read_lock, LOCK_global_system_variables, LOCK_user_conn, LOCK_bytes_sent, LOCK_bytes_received, LOCK_connection_count; extern pthread_mutex_t LOCK_server_started; extern rw_lock_t LOCK_sys_init_connect, LOCK_sys_init_slave; extern rw_lock_t LOCK_system_variables_hash; extern pthread_cond_t COND_refresh, COND_thread_count, COND_manager; extern pthread_cond_t COND_global_read_lock; extern pthread_attr_t connection_attrib; extern I_List threads; extern I_List key_caches; extern MY_BITMAP temp_pool; extern String my_empty_string; extern const String my_null_string; extern SHOW_VAR status_vars[]; extern struct system_variables max_system_variables; extern struct system_status_var global_status_var; extern struct rand_struct sql_rand; extern const char *opt_date_time_formats[]; extern KNOWN_DATE_TIME_FORMAT known_date_time_formats[]; extern String null_string; extern HASH open_cache, lock_db_cache; extern Table *unused_tables; extern const char* any_db; extern struct my_option my_long_options[]; extern const LEX_STRING view_type; extern scheduler_functions thread_scheduler; extern TYPELIB thread_handling_typelib; extern uint8_t uc_update_queries[SQLCOM_END+1]; extern uint sql_command_flags[]; extern TYPELIB log_output_typelib; /* optional things, have_* variables */ extern SHOW_COMP_OPTION have_community_features; extern handlerton *myisam_hton; extern handlerton *heap_hton; extern SHOW_COMP_OPTION have_symlink; extern SHOW_COMP_OPTION have_compress; extern pthread_t signal_thread; DRIZZLE_LOCK *mysql_lock_tables(THD *thd, Table **table, uint count, uint flags, bool *need_reopen); /* mysql_lock_tables() and open_table() flags bits */ #define DRIZZLE_LOCK_IGNORE_GLOBAL_READ_LOCK 0x0001 #define DRIZZLE_LOCK_IGNORE_FLUSH 0x0002 #define DRIZZLE_LOCK_NOTIFY_IF_NEED_REOPEN 0x0004 #define DRIZZLE_OPEN_TEMPORARY_ONLY 0x0008 #define DRIZZLE_LOCK_IGNORE_GLOBAL_READ_ONLY 0x0010 #define DRIZZLE_LOCK_PERF_SCHEMA 0x0020 void mysql_unlock_tables(THD *thd, DRIZZLE_LOCK *sql_lock); void mysql_unlock_read_tables(THD *thd, DRIZZLE_LOCK *sql_lock); void mysql_unlock_some_tables(THD *thd, Table **table,uint count); void mysql_lock_remove(THD *thd, DRIZZLE_LOCK *locked,Table *table, bool always_unlock); void mysql_lock_abort(THD *thd, Table *table, bool upgrade_lock); void mysql_lock_downgrade_write(THD *thd, Table *table, thr_lock_type new_lock_type); bool mysql_lock_abort_for_thread(THD *thd, Table *table); DRIZZLE_LOCK *mysql_lock_merge(DRIZZLE_LOCK *a,DRIZZLE_LOCK *b); TableList *mysql_lock_have_duplicate(THD *thd, TableList *needle, TableList *haystack); bool lock_global_read_lock(THD *thd); void unlock_global_read_lock(THD *thd); bool wait_if_global_read_lock(THD *thd, bool abort_on_refresh, bool is_not_commit); void start_waiting_global_read_lock(THD *thd); bool make_global_read_lock_block_commit(THD *thd); bool set_protect_against_global_read_lock(void); void unset_protect_against_global_read_lock(void); void broadcast_refresh(void); int try_transactional_lock(THD *thd, TableList *table_list); int check_transactional_lock(THD *thd, TableList *table_list); int set_handler_table_locks(THD *thd, TableList *table_list, bool transactional); /* Lock based on name */ int lock_and_wait_for_table_name(THD *thd, TableList *table_list); int lock_table_name(THD *thd, TableList *table_list, bool check_in_use); void unlock_table_name(THD *thd, TableList *table_list); bool wait_for_locked_table_names(THD *thd, TableList *table_list); bool lock_table_names(THD *thd, TableList *table_list); void unlock_table_names(THD *thd, TableList *table_list, TableList *last_table); bool lock_table_names_exclusively(THD *thd, TableList *table_list); bool is_table_name_exclusively_locked_by_this_thread(THD *thd, TableList *table_list); bool is_table_name_exclusively_locked_by_this_thread(THD *thd, uchar *key, int key_length); /* old unireg functions */ void unireg_init(ulong options); void unireg_end(void) __attribute__((noreturn)); bool mysql_create_frm(THD *thd, const char *file_name, const char *db, const char *table, HA_CREATE_INFO *create_info, List &create_field, uint key_count,KEY *key_info,handler *db_type); int rea_create_table(THD *thd, const char *path, const char *db, const char *table_name, HA_CREATE_INFO *create_info, List &create_field, uint key_count,KEY *key_info, handler *file); int format_number(uint inputflag,uint max_length,char * pos,uint length, char * *errpos); /* table.cc */ TABLE_SHARE *alloc_table_share(TableList *table_list, char *key, uint key_length); void init_tmp_table_share(THD *thd, TABLE_SHARE *share, const char *key, uint key_length, const char *table_name, const char *path); void free_table_share(TABLE_SHARE *share); int open_table_def(THD *thd, TABLE_SHARE *share, uint db_flags); void open_table_error(TABLE_SHARE *share, int error, int db_errno, int errarg); int open_table_from_share(THD *thd, TABLE_SHARE *share, const char *alias, uint db_stat, uint prgflag, uint ha_open_flags, Table *outparam, open_table_mode open_mode); int readfrm(const char *name, uchar **data, size_t *length); int writefrm(const char* name, const uchar* data, size_t len); int closefrm(Table *table, bool free_share); int read_string(File file, uchar* *to, size_t length); void free_blobs(Table *table); int set_zone(int nr,int min_zone,int max_zone); ulong convert_period_to_month(ulong period); ulong convert_month_to_period(ulong month); void get_date_from_daynr(long daynr,uint *year, uint *month, uint *day); my_time_t TIME_to_timestamp(THD *thd, const DRIZZLE_TIME *t, bool *not_exist); bool str_to_time_with_warn(const char *str,uint length,DRIZZLE_TIME *l_time); timestamp_type str_to_datetime_with_warn(const char *str, uint length, DRIZZLE_TIME *l_time, uint flags); void localtime_to_TIME(DRIZZLE_TIME *to, struct tm *from); void calc_time_from_sec(DRIZZLE_TIME *to, long seconds, long microseconds); void make_truncated_value_warning(THD *thd, DRIZZLE_ERROR::enum_warning_level level, const char *str_val, uint str_length, timestamp_type time_type, const char *field_name); bool date_add_interval(DRIZZLE_TIME *ltime, interval_type int_type, INTERVAL interval); bool calc_time_diff(DRIZZLE_TIME *l_time1, DRIZZLE_TIME *l_time2, int l_sign, int64_t *seconds_out, long *microseconds_out); extern LEX_STRING interval_type_to_name[]; extern DATE_TIME_FORMAT *date_time_format_make(timestamp_type format_type, const char *format_str, uint format_length); extern DATE_TIME_FORMAT *date_time_format_copy(THD *thd, DATE_TIME_FORMAT *format); const char *get_date_time_format_str(KNOWN_DATE_TIME_FORMAT *format, timestamp_type type); extern bool make_date_time(DATE_TIME_FORMAT *format, DRIZZLE_TIME *l_time, timestamp_type type, String *str); void make_datetime(const DATE_TIME_FORMAT *format, const DRIZZLE_TIME *l_time, String *str); void make_date(const DATE_TIME_FORMAT *format, const DRIZZLE_TIME *l_time, String *str); void make_time(const DATE_TIME_FORMAT *format, const DRIZZLE_TIME *l_time, String *str); int my_time_compare(DRIZZLE_TIME *a, DRIZZLE_TIME *b); uint64_t get_datetime_value(THD *thd, Item ***item_arg, Item **cache_arg, Item *warn_item, bool *is_null); int test_if_number(char *str,int *res,bool allow_wildcards); void change_byte(uchar *,uint,char,char); void init_read_record(READ_RECORD *info, THD *thd, Table *reg_form, SQL_SELECT *select, int use_record_cache, bool print_errors); void init_read_record_idx(READ_RECORD *info, THD *thd, Table *table, bool print_error, uint idx); void end_read_record(READ_RECORD *info); ha_rows filesort(THD *thd, Table *form,struct st_sort_field *sortorder, uint s_length, SQL_SELECT *select, ha_rows max_rows, bool sort_positions, ha_rows *examined_rows); void filesort_free_buffers(Table *table, bool full); void change_double_for_sort(double nr,uchar *to); double my_double_round(double value, int64_t dec, bool dec_unsigned, bool truncate); int get_quick_record(SQL_SELECT *select); int calc_weekday(long daynr,bool sunday_first_day_of_week); uint calc_week(DRIZZLE_TIME *l_time, uint week_behaviour, uint *year); void find_date(char *pos,uint *vek,uint flag); TYPELIB *convert_strings_to_array_type(char * *typelibs, char * *end); TYPELIB *typelib(MEM_ROOT *mem_root, List &strings); ulong get_form_pos(File file, uchar *head, TYPELIB *save_names); ulong make_new_entry(File file,uchar *fileinfo,TYPELIB *formnames, const char *newname); ulong next_io_size(ulong pos); void append_unescaped(String *res, const char *pos, uint length); int create_frm(THD *thd, const char *name, const char *db, const char *table, uint reclength, uchar *fileinfo, HA_CREATE_INFO *create_info, uint keys, KEY *key_info); int rename_file_ext(const char * from,const char * to,const char * ext); bool check_db_name(LEX_STRING *db); bool check_column_name(const char *name); bool check_table_name(const char *name, uint length); char *get_field(MEM_ROOT *mem, Field *field); bool get_field(MEM_ROOT *mem, Field *field, class String *res); char *fn_rext(char *name); /* Conversion functions */ uint build_table_filename(char *buff, size_t bufflen, const char *db, const char *table, const char *ext, uint flags); #define MYSQL50_TABLE_NAME_PREFIX "#mysql50#" #define MYSQL50_TABLE_NAME_PREFIX_LENGTH 9 /* Flags for conversion functions. */ #define FN_FROM_IS_TMP (1 << 0) #define FN_TO_IS_TMP (1 << 1) #define FN_IS_TMP (FN_FROM_IS_TMP | FN_TO_IS_TMP) #define NO_FRM_RENAME (1 << 2) /* item_func.cc */ Item *get_system_var(THD *thd, enum_var_type var_type, LEX_STRING name, LEX_STRING component); int get_var_with_binlog(THD *thd, enum_sql_command sql_command, LEX_STRING &name, user_var_entry **out_entry); /* log.cc */ bool flush_error_log(void); /* sql_list.cc */ void free_list(I_List *list); void free_list(I_List *list); /* Some inline functions for more speed */ inline bool add_item_to_list(THD *thd, Item *item) { return thd->lex->current_select->add_item_to_list(thd, item); } inline bool add_value_to_list(THD *thd, Item *value) { return thd->lex->value_list.push_back(value); } inline bool add_order_to_list(THD *thd, Item *item, bool asc) { return thd->lex->current_select->add_order_to_list(thd, item, asc); } inline bool add_group_to_list(THD *thd, Item *item, bool asc) { return thd->lex->current_select->add_group_to_list(thd, item, asc); } inline void mark_as_null_row(Table *table) { table->null_row=1; table->status|=STATUS_NULL_ROW; memset(table->null_flags, 255, table->s->null_bytes); } inline void table_case_convert(char * name, uint length) { if (lower_case_table_names) files_charset_info->cset->casedn(files_charset_info, name, length, name, length); } inline const char *table_case_name(HA_CREATE_INFO *info, const char *name) { return ((lower_case_table_names == 2 && info->alias) ? info->alias : name); } inline ulong sql_rnd() { ulong tmp= (ulong) (rand() * 0xffffffff); /* make all bits random */ return tmp; } Comp_creator *comp_eq_creator(bool invert); Comp_creator *comp_ge_creator(bool invert); Comp_creator *comp_gt_creator(bool invert); Comp_creator *comp_le_creator(bool invert); Comp_creator *comp_lt_creator(bool invert); Comp_creator *comp_ne_creator(bool invert); Item * all_any_subquery_creator(Item *left_expr, chooser_compare_func_creator cmp, bool all, SELECT_LEX *select_lex); /** clean/setup table fields and map. @param table Table structure pointer (which should be setup) @param table_list TableList structure pointer (owner of Table) @param tablenr table number */ inline void setup_table_map(Table *table, TableList *table_list, uint tablenr) { table->used_fields= 0; table->const_table= 0; table->null_row= 0; table->status= STATUS_NO_RECORD; table->maybe_null= table_list->outer_join; TableList *embedding= table_list->embedding; while (!table->maybe_null && embedding) { table->maybe_null= embedding->outer_join; embedding= embedding->embedding; } table->tablenr= tablenr; table->map= (table_map) 1 << tablenr; table->force_index= table_list->force_index; table->covering_keys= table->s->keys_for_keyread; table->merge_keys.clear_all(); } #include /* Factory API for creating Item_* instances */ /** convert a hex digit into number. */ inline int hexchar_to_int(char c) { if (c <= '9' && c >= '0') return c-'0'; c|=32; if (c <= 'f' && c >= 'a') return c-'a'+10; return -1; } /** return true if the table was created explicitly. */ inline bool is_user_table(Table * table) { const char *name= table->s->table_name.str; return strncmp(name, tmp_file_prefix, tmp_file_prefix_length); } #ifndef HAVE_LOG2 /* This will be slightly slower and perhaps a tiny bit less accurate than doing it the IEEE754 way but log2() should be available on C99 systems. */ static inline double log2(double x) { return (log(x) / M_LN2); } #endif /* Some functions that are different in the embedded library and the normal server */ extern "C" void unireg_abort(int exit_code) __attribute__((noreturn)); void kill_delayed_threads(void); bool check_stack_overrun(THD *thd, long margin, uchar *dummy); /** * Used by handlers to store things in schema tables * * @TODO These should be placed in an information_schema.h header * file once the new information schema design is finalized. */ #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 #endif /* DRIZZLE_SERVER_SERVER_INCLUDES_H */