MySQL 5.6.14 Source Code Document
|
#include "univ.i"
#include "dict0types.h"
#include "trx0types.h"
#include "ut0byte.h"
#include "mem0mem.h"
#include "btr0types.h"
#include "dict0load.ic"
Go to the source code of this file.
Enumerations | |
enum | dict_system_id_t { SYS_TABLES = 0, SYS_INDEXES, SYS_COLUMNS, SYS_FIELDS, SYS_FOREIGN, SYS_FOREIGN_COLS, SYS_TABLESPACES, SYS_DATAFILES, SYS_NUM_SYSTEM_TABLES } |
enum | dict_table_info_t { DICT_TABLE_LOAD_FROM_RECORD = 0, DICT_TABLE_LOAD_FROM_CACHE = 1 } |
enum | dict_check_t { DICT_CHECK_NONE_LOADED = 0, DICT_CHECK_SOME_LOADED, DICT_CHECK_ALL_LOADED } |
Functions | |
UNIV_INTERN void | dict_check_tablespaces_and_store_max_id (dict_check_t dict_check) |
UNIV_INTERN char * | dict_get_first_table_name_in_db (const char *name) |
UNIV_INTERN const char * | dict_load_table_low (const char *name, const rec_t *rec, dict_table_t **table) |
UNIV_INTERN const char * | dict_load_column_low (dict_table_t *table, mem_heap_t *heap, dict_col_t *column, table_id_t *table_id, const char **col_name, const rec_t *rec) |
UNIV_INTERN const char * | dict_load_index_low (byte *table_id, const char *table_name, mem_heap_t *heap, const rec_t *rec, ibool allocate, dict_index_t **index) |
UNIV_INTERN const char * | dict_load_field_low (byte *index_id, dict_index_t *index, dict_field_t *sys_field, ulint *pos, byte *last_index_id, mem_heap_t *heap, const rec_t *rec) |
UNIV_INTERN void | dict_save_data_dir_path (dict_table_t *table, char *filepath) |
UNIV_INTERN void | dict_get_and_save_data_dir_path (dict_table_t *table, bool dict_mutex_own) |
UNIV_INTERN dict_table_t * | dict_load_table (const char *name, ibool cached, dict_err_ignore_t ignore_err) |
UNIV_INTERN dict_table_t * | dict_load_table_on_id (table_id_t table_id, dict_err_ignore_t ignore_err) |
UNIV_INTERN void | dict_load_sys_table (dict_table_t *table) |
UNIV_INTERN dberr_t | dict_load_foreigns (const char *table_name, const char **col_names, bool check_recursive, bool check_charsets, dict_err_ignore_t ignore_err) __attribute__((nonnull(1) |
UNIV_INTERN void | dict_print (void) |
UNIV_INTERN const rec_t * | dict_startscan_system (btr_pcur_t *pcur, mtr_t *mtr, dict_system_id_t system_id) |
UNIV_INTERN const rec_t * | dict_getnext_system (btr_pcur_t *pcur, mtr_t *mtr) |
UNIV_INTERN const char * | dict_process_sys_tables_rec_and_mtr_commit (mem_heap_t *heap, const rec_t *rec, dict_table_t **table, dict_table_info_t status, mtr_t *mtr) |
UNIV_INTERN const char * | dict_process_sys_indexes_rec (mem_heap_t *heap, const rec_t *rec, dict_index_t *index, table_id_t *table_id) |
UNIV_INTERN const char * | dict_process_sys_columns_rec (mem_heap_t *heap, const rec_t *rec, dict_col_t *column, table_id_t *table_id, const char **col_name) |
UNIV_INTERN const char * | dict_process_sys_fields_rec (mem_heap_t *heap, const rec_t *rec, dict_field_t *sys_field, ulint *pos, index_id_t *index_id, index_id_t last_id) |
UNIV_INTERN const char * | dict_process_sys_foreign_rec (mem_heap_t *heap, const rec_t *rec, dict_foreign_t *foreign) |
UNIV_INTERN const char * | dict_process_sys_foreign_col_rec (mem_heap_t *heap, const rec_t *rec, const char **name, const char **for_col_name, const char **ref_col_name, ulint *pos) |
UNIV_INTERN const char * | dict_process_sys_tablespaces (mem_heap_t *heap, const rec_t *rec, ulint *space, const char **name, ulint *flags) |
UNIV_INTERN const char * | dict_process_sys_datafiles (mem_heap_t *heap, const rec_t *rec, ulint *space, const char **path) |
UNIV_INTERN char * | dict_get_first_path (ulint space, const char *name) |
UNIV_INTERN dberr_t | dict_update_filepath (ulint space_id, const char *filepath) |
UNIV_INTERN dberr_t | dict_insert_tablespace_and_filepath (ulint space, const char *name, const char *filepath, ulint fsp_flags) |
Variables | |
UNIV_INTERN dberr_t | warn_unused_result |
Loads to the memory cache database object definitions from dictionary tables
Created 4/24/1996 Heikki Tuuri
Definition in file dict0load.h.
enum dict_check_t |
Check type for dict_check_tablespaces_and_store_max_id()
Definition at line 62 of file dict0load.h.
enum dict_system_id_t |
enum that defines all system table IDs.
Definition at line 38 of file dict0load.h.
enum dict_table_info_t |
Status bit for dict_process_sys_tables_rec_and_mtr_commit()
DICT_TABLE_LOAD_FROM_RECORD |
Directly populate a dict_table_t structure with information from a SYS_TABLES record |
DICT_TABLE_LOAD_FROM_CACHE |
Check first whether dict_table_t is in the cache, if so, return it |
Definition at line 53 of file dict0load.h.
UNIV_INTERN void dict_check_tablespaces_and_store_max_id | ( | dict_check_t | dict_check | ) |
In a crash recovery we already have all the tablespace objects created. This function compares the space id information in the InnoDB data dictionary to what we already read with fil_load_single_table_tablespaces().
In a normal startup, we create the tablespace objects for every table in InnoDB's data dictionary, if the corresponding .ibd file exists. We also scan the biggest space id, and store it to fil_system. in: how to check
This function looks at each table defined in SYS_TABLES. It checks the tablespace for any table with a space_id > 0. It looks up the tablespace in SYS_DATAFILES to ensure the correct path.
In a crash recovery we already have all the tablespace objects created. This function compares the space id information in the InnoDB data dictionary to what we already read with fil_load_single_table_tablespaces().
In a normal startup, we create the tablespace objects for every table in InnoDB's data dictionary, if the corresponding .ibd file exists. We also scan the biggest space id, and store it to fil_system.
dict_check | in: how to check |
Definition at line 961 of file dict0load.cc.
UNIV_INTERN void dict_get_and_save_data_dir_path | ( | dict_table_t * | table, |
bool | dict_mutex_own | ||
) |
Make sure the data_file_name is saved in dict_table_t if needed. Try to read it from the file dictionary first, then from SYS_DATAFILES. in: true if dict_sys->mutex is owned already
table | in/out: table |
UNIV_INTERN char* dict_get_first_path | ( | ulint | space, |
const char * | name | ||
) |
Get the filepath for a spaceid from SYS_DATAFILES. This function provides a temporary heap which is used for the table lookup, but not for the path. The caller must free the memory for the path returned. This function can return NULL if the space ID is not found in SYS_DATAFILES, then the caller will assume that the ibd file is in the normal datadir.
Gets the filepath for a spaceid from SYS_DATAFILES and checks it against the contents of a link file. This function is called when there is no fil_node_t entry for this space ID so both durable locations on disk must be checked and compared. We use a temporary heap here for the table lookup, but not for the path returned which the caller must free. This function can return NULL if the space ID is not found in SYS_DATAFILES, then the caller will assume that the ibd file is in the normal datadir.
space | in: space id |
name | in: tablespace name |
Definition at line 786 of file dict0load.cc.
UNIV_INTERN char* dict_get_first_table_name_in_db | ( | const char * | name | ) |
Finds the first table name in the given database.
Finds the first table name in the given database.
name | in: database name which ends in '/' |
Definition at line 93 of file dict0load.cc.
UNIV_INTERN const rec_t* dict_getnext_system | ( | btr_pcur_t * | pcur, |
mtr_t * | mtr | ||
) |
This function get the next system table record as we scan the table.
This function gets the next system table record as it scans the table.
pcur | in/out: persistent cursor to the record |
mtr | in: the mini-transaction |
Definition at line 298 of file dict0load.cc.
UNIV_INTERN dberr_t dict_insert_tablespace_and_filepath | ( | ulint | space, |
const char * | name, | ||
const char * | filepath, | ||
ulint | fsp_flags | ||
) |
Insert records into SYS_TABLESPACES and SYS_DATAFILES.
Insert records into SYS_TABLESPACES and SYS_DATAFILES.
space | in: space id |
name | in: talespace name |
filepath | in: filepath |
fsp_flags | in: tablespace flags |
Definition at line 913 of file dict0load.cc.
UNIV_INTERN const char* dict_load_column_low | ( | dict_table_t * | table, |
mem_heap_t * | heap, | ||
dict_col_t * | column, | ||
table_id_t * | table_id, | ||
const char ** | col_name, | ||
const rec_t * | rec | ||
) |
Loads a table column definition from a SYS_COLUMNS record to dict_table_t.
Loads a table column definition from a SYS_COLUMNS record to dict_table_t.
table | in/out: table, could be NULL if we just populate a dict_column_t struct with information from a SYS_COLUMNS record |
heap | in/out: memory heap for temporary storage |
column | out: dict_column_t to fill, or NULL if table != NULL |
table_id | out: table id |
col_name | out: column name |
rec | in: SYS_COLUMNS record |
Definition at line 1175 of file dict0load.cc.
UNIV_INTERN const char* dict_load_field_low | ( | byte * | index_id, |
dict_index_t * | index, | ||
dict_field_t * | sys_field, | ||
ulint * | pos, | ||
byte * | last_index_id, | ||
mem_heap_t * | heap, | ||
const rec_t * | rec | ||
) |
Loads an index field definition from a SYS_FIELDS record to dict_index_t.
Loads an index field definition from a SYS_FIELDS record to dict_index_t.
index_id | in/out: index id (8 bytes) an "in" value if index != NULL and "out" if index == NULL |
index | in/out: index, could be NULL if we just populate a dict_field_t struct with information from a SYS_FIELDS record |
sys_field | out: dict_field_t to be filled |
pos | out: Field position |
last_index_id | in: last index id |
heap | in/out: memory heap for temporary storage |
rec | in: SYS_FIELDS record |
Definition at line 1425 of file dict0load.cc.
UNIV_INTERN dberr_t dict_load_foreigns | ( | const char * | table_name, |
const char ** | col_names, | ||
bool | check_recursive, | ||
bool | check_charsets, | ||
dict_err_ignore_t | ignore_err | ||
) |
Loads foreign key constraints where the table is either the foreign key holder or where the table is referenced by a foreign key. Adds these constraints to the data dictionary. Note that we know that the dictionary cache already contains all constraints where the other relevant table is already in the dictionary cache.
table_name | in: table name |
col_names | in: column names, or NULL to use table->col_names |
check_recursive | in: Whether to check recursive load of tables chained by FK |
check_charsets | in: whether to check charset compatibility |
ignore_err | in: error to be ignored |
UNIV_INTERN const char* dict_load_index_low | ( | byte * | table_id, |
const char * | table_name, | ||
mem_heap_t * | heap, | ||
const rec_t * | rec, | ||
ibool | allocate, | ||
dict_index_t ** | index | ||
) |
Loads an index definition from a SYS_INDEXES record to dict_index_t. If allocate=TRUE, we will create a dict_index_t structure and fill it accordingly. If allocated=FALSE, the dict_index_t will be supplied by the caller and filled with information read from the record.
Loads an index definition from a SYS_INDEXES record to dict_index_t. If allocate=TRUE, we will create a dict_index_t structure and fill it accordingly. If allocated=FALSE, the dict_index_t will be supplied by the caller and filled with information read from the record.
table_id | in/out: table id (8 bytes), an "in" value if allocate=TRUE and "out" when allocate=FALSE |
table_name | in: table name |
heap | in/out: temporary memory heap |
rec | in: SYS_INDEXES record |
allocate | in: TRUE=allocate *index, FALSE=fill in a pre-allocated *index |
index | out,own: index, or NULL |
Definition at line 1629 of file dict0load.cc.
UNIV_INTERN void dict_load_sys_table | ( | dict_table_t * | table | ) |
This function is called when the database is booted. Loads system table index definitions except for the clustered index which is added to the dictionary cache at booting before calling this function. in: system table
UNIV_INTERN dict_table_t* dict_load_table | ( | const char * | name, |
ibool | cached, | ||
dict_err_ignore_t | ignore_err | ||
) |
Loads a table definition and also all its index definitions, and also the cluster definition if the table is a member in a cluster. Also loads all foreign key constraints where the foreign key is in the table or where a foreign key references columns in this table.
name | in: table name in the databasename/tablename format |
cached | in: TRUE=add to cache, FALSE=do not |
UNIV_INTERN const char* dict_load_table_low | ( | const char * | name, |
const rec_t * | rec, | ||
dict_table_t ** | table | ||
) |
Loads a table definition from a SYS_TABLES record to dict_table_t. Does not load any columns or indexes.
name | in: table name |
rec | in: SYS_TABLES record |
UNIV_INTERN dict_table_t* dict_load_table_on_id | ( | table_id_t | table_id, |
dict_err_ignore_t | ignore_err | ||
) |
Loads a table object based on the table id.
table_id | in: table id |
UNIV_INTERN void dict_print | ( | void | ) |
Prints to the standard output information on all tables found in the data dictionary system table.
Definition at line 176 of file dict0load.cc.
UNIV_INTERN const char* dict_process_sys_columns_rec | ( | mem_heap_t * | heap, |
const rec_t * | rec, | ||
dict_col_t * | column, | ||
table_id_t * | table_id, | ||
const char ** | col_name | ||
) |
This function parses a SYS_COLUMNS record and populate a dict_column_t structure with the information from the record.
This function parses a SYS_COLUMNS record and populate a dict_column_t structure with the information from the record.
heap | in/out: heap memory |
rec | in: current SYS_COLUMNS rec |
column | out: dict_col_t to be filled |
table_id | out: table id |
col_name | out: column name |
Definition at line 407 of file dict0load.cc.
UNIV_INTERN const char* dict_process_sys_datafiles | ( | mem_heap_t * | heap, |
const rec_t * | rec, | ||
ulint * | space, | ||
const char ** | path | ||
) |
This function parses a SYS_DATAFILES record, extracts necessary information from the record and returns to caller.
This function parses a SYS_DATAFILES record, extracts necessary information from the record and returns it to the caller.
heap | in/out: heap memory |
rec | in: current SYS_DATAFILES rec |
space | out: space id |
path | out: datafile paths |
Definition at line 683 of file dict0load.cc.
UNIV_INTERN const char* dict_process_sys_fields_rec | ( | mem_heap_t * | heap, |
const rec_t * | rec, | ||
dict_field_t * | sys_field, | ||
ulint * | pos, | ||
index_id_t * | index_id, | ||
index_id_t | last_id | ||
) |
This function parses a SYS_FIELDS record and populate a dict_field_t structure with the information from the record.
This function parses a SYS_FIELDS record and populates a dict_field_t structure with the information from the record.
heap | in/out: heap memory |
rec | in: current SYS_FIELDS rec |
sys_field | out: dict_field_t to be filled |
pos | out: Field position |
index_id | out: current index id |
last_id | in: previous index id |
Definition at line 430 of file dict0load.cc.
UNIV_INTERN const char* dict_process_sys_foreign_col_rec | ( | mem_heap_t * | heap, |
const rec_t * | rec, | ||
const char ** | name, | ||
const char ** | for_col_name, | ||
const char ** | ref_col_name, | ||
ulint * | pos | ||
) |
This function parses a SYS_FOREIGN_COLS record and extract necessary information from the record and return to caller.
This function parses a SYS_FOREIGN_COLS record and extract necessary information from the record and return to caller.
heap | in/out: heap memory |
rec | in: current SYS_FOREIGN_COLS rec |
name | out: foreign key constraint name |
for_col_name | out: referencing column name |
ref_col_name | out: referenced column name in referenced table |
pos | out: column position |
Definition at line 546 of file dict0load.cc.
UNIV_INTERN const char* dict_process_sys_foreign_rec | ( | mem_heap_t * | heap, |
const rec_t * | rec, | ||
dict_foreign_t * | foreign | ||
) |
This function parses a SYS_FOREIGN record and populate a dict_foreign_t structure with the information from the record. For detail information about SYS_FOREIGN fields, please refer to dict_load_foreign() function
This function parses a SYS_FOREIGN record and populate a dict_foreign_t structure with the information from the record. For detail information about SYS_FOREIGN fields, please refer to dict_load_foreign() function.
heap | in/out: heap memory |
rec | in: current SYS_FOREIGN rec |
foreign | out: dict_foreign_t struct to be filled |
Definition at line 465 of file dict0load.cc.
UNIV_INTERN const char* dict_process_sys_indexes_rec | ( | mem_heap_t * | heap, |
const rec_t * | rec, | ||
dict_index_t * | index, | ||
table_id_t * | table_id | ||
) |
This function parses a SYS_INDEXES record and populate a dict_index_t structure with the information from the record. For detail information about SYS_INDEXES fields, please refer to dict_boot() function.
This function parses a SYS_INDEXES record and populate a dict_index_t structure with the information from the record. For detail information about SYS_INDEXES fields, please refer to dict_boot() function.
heap | in/out: heap memory |
rec | in: current SYS_INDEXES rec |
index | out: index to be filled |
table_id | out: index table id |
Definition at line 380 of file dict0load.cc.
UNIV_INTERN const char* dict_process_sys_tables_rec_and_mtr_commit | ( | mem_heap_t * | heap, |
const rec_t * | rec, | ||
dict_table_t ** | table, | ||
dict_table_info_t | status, | ||
mtr_t * | mtr | ||
) |
This function processes one SYS_TABLES record and populate the dict_table_t struct for the table. Extracted out of dict_print() to be used by both monitor table output and information schema innodb_sys_tables output.
This function processes one SYS_TABLES record and populate the dict_table_t struct for the table. Extracted out of dict_print() to be used by both monitor table output and information schema innodb_sys_tables output.
heap | in/out: temporary memory heap |
rec | in: SYS_TABLES record |
table | out: dict_table_t to fill |
status | in: status bit controls options such as whether we shall look for dict_table_t from cache first |
mtr | in/out: mini-transaction, will be committed |
Definition at line 322 of file dict0load.cc.
UNIV_INTERN const char* dict_process_sys_tablespaces | ( | mem_heap_t * | heap, |
const rec_t * | rec, | ||
ulint * | space, | ||
const char ** | name, | ||
ulint * | flags | ||
) |
This function parses a SYS_TABLESPACES record, extracts necessary information from the record and returns to caller.
This function parses a SYS_TABLESPACES record, extracts necessary information from the record and returns to caller.
heap | in/out: heap memory |
rec | in: current SYS_TABLESPACES rec |
space | out: space id |
name | out: tablespace name |
flags | out: tablespace flags |
Definition at line 616 of file dict0load.cc.
UNIV_INTERN void dict_save_data_dir_path | ( | dict_table_t * | table, |
char * | filepath | ||
) |
Using the table->heap, copy the null-terminated filepath into table->data_dir_path and put a null byte before the extension. This allows SHOW CREATE TABLE to return the correct DATA DIRECTORY path. Make this data directory path only if it has not yet been saved. in: filepath of tablespace
table | in/out: table |
UNIV_INTERN const rec_t* dict_startscan_system | ( | btr_pcur_t * | pcur, |
mtr_t * | mtr, | ||
dict_system_id_t | system_id | ||
) |
This function opens a system table, and return the first record.
This function opens a system table, and returns the first record.
pcur | out: persistent cursor to the record |
mtr | in: the mini-transaction |
system_id | in: which system table to open |
Definition at line 268 of file dict0load.cc.
UNIV_INTERN dberr_t dict_update_filepath | ( | ulint | space_id, |
const char * | filepath | ||
) |
Update the record for space_id in SYS_TABLESPACES to this filepath.
Update the record for space_id in SYS_TABLESPACES to this filepath.
space_id | in: space id |
filepath | in: filepath |
Definition at line 856 of file dict0load.cc.