2001-02-17 13:19:19 +01:00
|
|
|
/******************************************************
|
|
|
|
SQL parser
|
|
|
|
|
|
|
|
(c) 1996 Innobase Oy
|
|
|
|
|
|
|
|
Created 11/19/1996 Heikki Tuuri
|
|
|
|
*******************************************************/
|
|
|
|
|
|
|
|
#ifndef pars0pars_h
|
|
|
|
#define pars0pars_h
|
|
|
|
|
|
|
|
#include "univ.i"
|
|
|
|
#include "que0types.h"
|
|
|
|
#include "usr0types.h"
|
|
|
|
#include "pars0types.h"
|
|
|
|
#include "row0types.h"
|
|
|
|
#include "trx0types.h"
|
|
|
|
|
|
|
|
extern int yydebug;
|
|
|
|
|
|
|
|
/* If the following is set TRUE, the lexer will print the SQL string
|
|
|
|
as it tokenizes it */
|
|
|
|
|
2004-03-11 15:36:19 +01:00
|
|
|
#ifdef UNIV_SQL_DEBUG
|
2001-02-17 13:19:19 +01:00
|
|
|
extern ibool pars_print_lexed;
|
2004-03-11 15:36:19 +01:00
|
|
|
#endif /* UNIV_SQL_DEBUG */
|
2001-02-17 13:19:19 +01:00
|
|
|
|
|
|
|
/* Global variable used while parsing a single procedure or query : the code is
|
|
|
|
NOT re-entrant */
|
|
|
|
extern sym_tab_t* pars_sym_tab_global;
|
|
|
|
|
|
|
|
extern pars_res_word_t pars_to_char_token;
|
|
|
|
extern pars_res_word_t pars_to_number_token;
|
|
|
|
extern pars_res_word_t pars_to_binary_token;
|
|
|
|
extern pars_res_word_t pars_binary_to_number_token;
|
|
|
|
extern pars_res_word_t pars_substr_token;
|
|
|
|
extern pars_res_word_t pars_replstr_token;
|
|
|
|
extern pars_res_word_t pars_concat_token;
|
|
|
|
extern pars_res_word_t pars_length_token;
|
|
|
|
extern pars_res_word_t pars_instr_token;
|
|
|
|
extern pars_res_word_t pars_sysdate_token;
|
|
|
|
extern pars_res_word_t pars_printf_token;
|
|
|
|
extern pars_res_word_t pars_assert_token;
|
|
|
|
extern pars_res_word_t pars_rnd_token;
|
|
|
|
extern pars_res_word_t pars_rnd_str_token;
|
|
|
|
extern pars_res_word_t pars_count_token;
|
|
|
|
extern pars_res_word_t pars_sum_token;
|
|
|
|
extern pars_res_word_t pars_distinct_token;
|
Applied innodb-5.1-ss269 snapshot.
Fixed BUGS:
#3300: "UPDATE statement with no index column in where condition locks
all rows"
Implement semi-consistent read to reduce lock conflicts at the cost
of breaking serializability.
ha_innobase::unlock_row(): reset the "did semi consistent read" flag
ha_innobase::was_semi_consistent_read(),
ha_innobase::try_semi_consistent_read(): new methods
row_prebuilt_t, row_create_prebuilt(): add field row_read_type for
keeping track of semi-consistent reads
row_vers_build_for_semi_consistent_read(),
row_sel_build_committed_vers_for_mysql(): new functions
row_search_for_mysql(): implement semi-consistent reads
#9802: "Foreign key checks disallow alter table".
Added test cases.
#12456: "Cursor shows incorrect data - DML does not affect,
probably caching"
This patch implements a high-granularity read view to be used with
cursors. In this high-granularity consistent read view modifications
done by the creating transaction after the cursor is created or
future transactions are not visible. But those modifications that
transaction did before the cursor was created are visible.
#12701: "Support >4GB buffer pool and log files on 64-bit Windows"
Do not call os_file_create_tmpfile() at runtime. Instead, create all
tempfiles at startup and guard access to them with mutexes.
#13778: "If FOREIGN_KEY_CHECKS=0, one can create inconsistent FOREIGN KEYs".
When FOREIGN_KEY_CHECKS=0 we still need to check that datatypes between
foreign key references are compatible.
#14189: "VARBINARY and BINARY variables: trailing space ignored with InnoDB"
innobase_init(): Assert that
DATA_MYSQL_BINARY_CHARSET_COLL == my_charset_bin.number.
dtype_get_pad_char(): Do not pad VARBINARY or BINARY columns.
row_ins_cascade_calc_update_vec(): Refuse ON UPDATE CASCADE when trying
to change the length of a VARBINARY column that refers to or is referenced
by a BINARY column. BINARY columns are no longer padded on comparison,
and thus they cannot be padded on storage either.
#14747: "Race condition can cause btr_search_drop_page_hash_index() to crash"
Note that buf_block_t::index should be protected by btr_search_latch
or an s-latch or x-latch on the index page.
btr_search_drop_page_hash_index(): Read block->index while holding
btr_search_latch and use the cached value in the loop. Remove some
redundant assertions.
#15108: "mysqld crashes when innodb_log_file_size is set > 4G"
#15308: "Problem of Order with Enum Column in Primary Key"
#15550: "mysqld crashes in printing a FOREIGN KEY error in InnoDB"
row_ins_foreign_report_add_err(): When printing the parent record,
use the index in the parent table rather than the index in the child table.
#15653: "Slow inserts to InnoDB if many thousands of .ibd files"
Keep track on unflushed modifications to file spaces. When there are tens
of thousands of file spaces, flushing all files in fil_flush_file_spaces()
would be very slow.
fil_flush_file_spaces(): Only flush unflushed file spaces.
fil_space_t, fil_system_t: Add a list of unflushed spaces.
#15991: "innodb-file-per-table + symlink database + rename = cr"
os_file_handle_error(): Map the error codes EXDEV, ENOTDIR, and EISDIR
to the new code OS_FILE_PATH_ERROR. Treat this code as OS_FILE_PATH_ERROR.
This fixes the crash on RENAME TABLE when the .ibd file is a symbolic link
to a different file system.
#16157: "InnoDB crashes when main location settings are empty"
This patch is from Heikki.
#16298: "InnoDB segfaults in INSERTs in upgrade of 4.0 -> 5.0 tables
with VARCHAR BINARY"
dict_load_columns(): Set the charset-collation code
DATA_MYSQL_BINARY_CHARSET_COLL for those binary string columns
that lack a charset-collation code, i.e., the tables were created
with an older version of MySQL/InnoDB than 4.1.2.
#16229: "MySQL/InnoDB uses full explicit table locks in trigger processing"
Take a InnoDB table lock only if user has explicitly requested a table
lock. Added some additional comments to store_lock() and external_lock().
#16387: "InnoDB crash when dropping a foreign key <table>_ibfk_0"
Do not mistake TABLENAME_ibfk_0 for auto-generated id.
dict_table_get_highest_foreign_id(): Ignore foreign constraint
identifiers starting with the pattern TABLENAME_ibfk_0.
#16582: "InnoDB: Error in an adaptive hash index pointer to page"
Account for a race condition when dropping the adaptive hash index
for a B-tree page.
btr_search_drop_page_hash_index(): Retry the operation if a hash index
with different parameters was built meanwhile. Add diagnostics for the
case that hash node pointers to the page remain.
btr_search_info_update_hash(), btr_search_info_update_slow():
Document the parameter "info" as in/out.
#16814: "SHOW INNODB STATUS format error in LATEST FOREIGN KEY ERROR
section"
Add a missing newline to the LAST FOREIGN KEY ERROR section in SHOW
INNODB STATUS output.
dict_foreign_error_report(): Always print a newline after invoking
dict_print_info_on_foreign_key_in_create_format().
#16827: "Better InnoDB error message if ibdata files omitted from my.cnf"
#17126: "CHECK TABLE on InnoDB causes a short hang during check of adaptive
hash"
CHECK TABLE blocking other queries, by releasing the btr_search_latch
periodically during the adaptive hash table validation.
#17405: "Valgrind: conditional jump or move depends on unititialised values"
buf_block_init(): Reset magic_n, buf_fix_count and io_fix to avoid
testing uninitialized variables.
2006-03-10 17:22:21 +01:00
|
|
|
extern pars_res_word_t pars_binary_token;
|
|
|
|
extern pars_res_word_t pars_blob_token;
|
2001-02-17 13:19:19 +01:00
|
|
|
extern pars_res_word_t pars_int_token;
|
|
|
|
extern pars_res_word_t pars_char_token;
|
|
|
|
extern pars_res_word_t pars_float_token;
|
|
|
|
extern pars_res_word_t pars_update_token;
|
|
|
|
extern pars_res_word_t pars_asc_token;
|
|
|
|
extern pars_res_word_t pars_desc_token;
|
|
|
|
extern pars_res_word_t pars_open_token;
|
|
|
|
extern pars_res_word_t pars_close_token;
|
|
|
|
extern pars_res_word_t pars_consistent_token;
|
|
|
|
extern pars_res_word_t pars_unique_token;
|
|
|
|
extern pars_res_word_t pars_clustered_token;
|
|
|
|
|
|
|
|
extern ulint pars_star_denoter;
|
Applied innodb-5.1-ss269 snapshot.
Fixed BUGS:
#3300: "UPDATE statement with no index column in where condition locks
all rows"
Implement semi-consistent read to reduce lock conflicts at the cost
of breaking serializability.
ha_innobase::unlock_row(): reset the "did semi consistent read" flag
ha_innobase::was_semi_consistent_read(),
ha_innobase::try_semi_consistent_read(): new methods
row_prebuilt_t, row_create_prebuilt(): add field row_read_type for
keeping track of semi-consistent reads
row_vers_build_for_semi_consistent_read(),
row_sel_build_committed_vers_for_mysql(): new functions
row_search_for_mysql(): implement semi-consistent reads
#9802: "Foreign key checks disallow alter table".
Added test cases.
#12456: "Cursor shows incorrect data - DML does not affect,
probably caching"
This patch implements a high-granularity read view to be used with
cursors. In this high-granularity consistent read view modifications
done by the creating transaction after the cursor is created or
future transactions are not visible. But those modifications that
transaction did before the cursor was created are visible.
#12701: "Support >4GB buffer pool and log files on 64-bit Windows"
Do not call os_file_create_tmpfile() at runtime. Instead, create all
tempfiles at startup and guard access to them with mutexes.
#13778: "If FOREIGN_KEY_CHECKS=0, one can create inconsistent FOREIGN KEYs".
When FOREIGN_KEY_CHECKS=0 we still need to check that datatypes between
foreign key references are compatible.
#14189: "VARBINARY and BINARY variables: trailing space ignored with InnoDB"
innobase_init(): Assert that
DATA_MYSQL_BINARY_CHARSET_COLL == my_charset_bin.number.
dtype_get_pad_char(): Do not pad VARBINARY or BINARY columns.
row_ins_cascade_calc_update_vec(): Refuse ON UPDATE CASCADE when trying
to change the length of a VARBINARY column that refers to or is referenced
by a BINARY column. BINARY columns are no longer padded on comparison,
and thus they cannot be padded on storage either.
#14747: "Race condition can cause btr_search_drop_page_hash_index() to crash"
Note that buf_block_t::index should be protected by btr_search_latch
or an s-latch or x-latch on the index page.
btr_search_drop_page_hash_index(): Read block->index while holding
btr_search_latch and use the cached value in the loop. Remove some
redundant assertions.
#15108: "mysqld crashes when innodb_log_file_size is set > 4G"
#15308: "Problem of Order with Enum Column in Primary Key"
#15550: "mysqld crashes in printing a FOREIGN KEY error in InnoDB"
row_ins_foreign_report_add_err(): When printing the parent record,
use the index in the parent table rather than the index in the child table.
#15653: "Slow inserts to InnoDB if many thousands of .ibd files"
Keep track on unflushed modifications to file spaces. When there are tens
of thousands of file spaces, flushing all files in fil_flush_file_spaces()
would be very slow.
fil_flush_file_spaces(): Only flush unflushed file spaces.
fil_space_t, fil_system_t: Add a list of unflushed spaces.
#15991: "innodb-file-per-table + symlink database + rename = cr"
os_file_handle_error(): Map the error codes EXDEV, ENOTDIR, and EISDIR
to the new code OS_FILE_PATH_ERROR. Treat this code as OS_FILE_PATH_ERROR.
This fixes the crash on RENAME TABLE when the .ibd file is a symbolic link
to a different file system.
#16157: "InnoDB crashes when main location settings are empty"
This patch is from Heikki.
#16298: "InnoDB segfaults in INSERTs in upgrade of 4.0 -> 5.0 tables
with VARCHAR BINARY"
dict_load_columns(): Set the charset-collation code
DATA_MYSQL_BINARY_CHARSET_COLL for those binary string columns
that lack a charset-collation code, i.e., the tables were created
with an older version of MySQL/InnoDB than 4.1.2.
#16229: "MySQL/InnoDB uses full explicit table locks in trigger processing"
Take a InnoDB table lock only if user has explicitly requested a table
lock. Added some additional comments to store_lock() and external_lock().
#16387: "InnoDB crash when dropping a foreign key <table>_ibfk_0"
Do not mistake TABLENAME_ibfk_0 for auto-generated id.
dict_table_get_highest_foreign_id(): Ignore foreign constraint
identifiers starting with the pattern TABLENAME_ibfk_0.
#16582: "InnoDB: Error in an adaptive hash index pointer to page"
Account for a race condition when dropping the adaptive hash index
for a B-tree page.
btr_search_drop_page_hash_index(): Retry the operation if a hash index
with different parameters was built meanwhile. Add diagnostics for the
case that hash node pointers to the page remain.
btr_search_info_update_hash(), btr_search_info_update_slow():
Document the parameter "info" as in/out.
#16814: "SHOW INNODB STATUS format error in LATEST FOREIGN KEY ERROR
section"
Add a missing newline to the LAST FOREIGN KEY ERROR section in SHOW
INNODB STATUS output.
dict_foreign_error_report(): Always print a newline after invoking
dict_print_info_on_foreign_key_in_create_format().
#16827: "Better InnoDB error message if ibdata files omitted from my.cnf"
#17126: "CHECK TABLE on InnoDB causes a short hang during check of adaptive
hash"
CHECK TABLE blocking other queries, by releasing the btr_search_latch
periodically during the adaptive hash table validation.
#17405: "Valgrind: conditional jump or move depends on unititialised values"
buf_block_init(): Reset magic_n, buf_fix_count and io_fix to avoid
testing uninitialized variables.
2006-03-10 17:22:21 +01:00
|
|
|
|
2001-02-17 13:19:19 +01:00
|
|
|
/* Procedure parameter types */
|
|
|
|
#define PARS_INPUT 0
|
|
|
|
#define PARS_OUTPUT 1
|
|
|
|
#define PARS_NOT_PARAM 2
|
|
|
|
|
|
|
|
int
|
|
|
|
yyparse(void);
|
|
|
|
|
|
|
|
/*****************************************************************
|
|
|
|
Parses an SQL string returning the query graph. */
|
|
|
|
|
|
|
|
que_t*
|
|
|
|
pars_sql(
|
|
|
|
/*=====*/
|
2004-05-17 13:40:31 +02:00
|
|
|
/* out, own: the query graph */
|
|
|
|
const char* str); /* in: SQL string */
|
2001-02-17 13:19:19 +01:00
|
|
|
/*****************************************************************
|
|
|
|
Retrieves characters to the lexical analyzer. */
|
|
|
|
|
|
|
|
void
|
|
|
|
pars_get_lex_chars(
|
|
|
|
/*===============*/
|
|
|
|
char* buf, /* in/out: buffer where to copy */
|
|
|
|
int* result, /* out: number of characters copied or EOF */
|
|
|
|
int max_size); /* in: maximum number of characters which fit
|
|
|
|
in the buffer */
|
|
|
|
/*****************************************************************
|
|
|
|
Called by yyparse on error. */
|
|
|
|
|
|
|
|
void
|
|
|
|
yyerror(
|
|
|
|
/*====*/
|
2004-05-14 15:06:21 +02:00
|
|
|
const char* s); /* in: error message string */
|
2001-02-17 13:19:19 +01:00
|
|
|
/*************************************************************************
|
|
|
|
Parses a variable declaration. */
|
|
|
|
|
|
|
|
sym_node_t*
|
|
|
|
pars_variable_declaration(
|
|
|
|
/*======================*/
|
|
|
|
/* out, own: symbol table node of type
|
|
|
|
SYM_VAR */
|
|
|
|
sym_node_t* node, /* in: symbol table node allocated for the
|
|
|
|
id of the variable */
|
|
|
|
pars_res_word_t* type); /* in: pointer to a type token */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a function expression. */
|
|
|
|
|
|
|
|
func_node_t*
|
|
|
|
pars_func(
|
|
|
|
/*======*/
|
|
|
|
/* out, own: function node in a query tree */
|
Applied innodb-5.1-ss269 snapshot.
Fixed BUGS:
#3300: "UPDATE statement with no index column in where condition locks
all rows"
Implement semi-consistent read to reduce lock conflicts at the cost
of breaking serializability.
ha_innobase::unlock_row(): reset the "did semi consistent read" flag
ha_innobase::was_semi_consistent_read(),
ha_innobase::try_semi_consistent_read(): new methods
row_prebuilt_t, row_create_prebuilt(): add field row_read_type for
keeping track of semi-consistent reads
row_vers_build_for_semi_consistent_read(),
row_sel_build_committed_vers_for_mysql(): new functions
row_search_for_mysql(): implement semi-consistent reads
#9802: "Foreign key checks disallow alter table".
Added test cases.
#12456: "Cursor shows incorrect data - DML does not affect,
probably caching"
This patch implements a high-granularity read view to be used with
cursors. In this high-granularity consistent read view modifications
done by the creating transaction after the cursor is created or
future transactions are not visible. But those modifications that
transaction did before the cursor was created are visible.
#12701: "Support >4GB buffer pool and log files on 64-bit Windows"
Do not call os_file_create_tmpfile() at runtime. Instead, create all
tempfiles at startup and guard access to them with mutexes.
#13778: "If FOREIGN_KEY_CHECKS=0, one can create inconsistent FOREIGN KEYs".
When FOREIGN_KEY_CHECKS=0 we still need to check that datatypes between
foreign key references are compatible.
#14189: "VARBINARY and BINARY variables: trailing space ignored with InnoDB"
innobase_init(): Assert that
DATA_MYSQL_BINARY_CHARSET_COLL == my_charset_bin.number.
dtype_get_pad_char(): Do not pad VARBINARY or BINARY columns.
row_ins_cascade_calc_update_vec(): Refuse ON UPDATE CASCADE when trying
to change the length of a VARBINARY column that refers to or is referenced
by a BINARY column. BINARY columns are no longer padded on comparison,
and thus they cannot be padded on storage either.
#14747: "Race condition can cause btr_search_drop_page_hash_index() to crash"
Note that buf_block_t::index should be protected by btr_search_latch
or an s-latch or x-latch on the index page.
btr_search_drop_page_hash_index(): Read block->index while holding
btr_search_latch and use the cached value in the loop. Remove some
redundant assertions.
#15108: "mysqld crashes when innodb_log_file_size is set > 4G"
#15308: "Problem of Order with Enum Column in Primary Key"
#15550: "mysqld crashes in printing a FOREIGN KEY error in InnoDB"
row_ins_foreign_report_add_err(): When printing the parent record,
use the index in the parent table rather than the index in the child table.
#15653: "Slow inserts to InnoDB if many thousands of .ibd files"
Keep track on unflushed modifications to file spaces. When there are tens
of thousands of file spaces, flushing all files in fil_flush_file_spaces()
would be very slow.
fil_flush_file_spaces(): Only flush unflushed file spaces.
fil_space_t, fil_system_t: Add a list of unflushed spaces.
#15991: "innodb-file-per-table + symlink database + rename = cr"
os_file_handle_error(): Map the error codes EXDEV, ENOTDIR, and EISDIR
to the new code OS_FILE_PATH_ERROR. Treat this code as OS_FILE_PATH_ERROR.
This fixes the crash on RENAME TABLE when the .ibd file is a symbolic link
to a different file system.
#16157: "InnoDB crashes when main location settings are empty"
This patch is from Heikki.
#16298: "InnoDB segfaults in INSERTs in upgrade of 4.0 -> 5.0 tables
with VARCHAR BINARY"
dict_load_columns(): Set the charset-collation code
DATA_MYSQL_BINARY_CHARSET_COLL for those binary string columns
that lack a charset-collation code, i.e., the tables were created
with an older version of MySQL/InnoDB than 4.1.2.
#16229: "MySQL/InnoDB uses full explicit table locks in trigger processing"
Take a InnoDB table lock only if user has explicitly requested a table
lock. Added some additional comments to store_lock() and external_lock().
#16387: "InnoDB crash when dropping a foreign key <table>_ibfk_0"
Do not mistake TABLENAME_ibfk_0 for auto-generated id.
dict_table_get_highest_foreign_id(): Ignore foreign constraint
identifiers starting with the pattern TABLENAME_ibfk_0.
#16582: "InnoDB: Error in an adaptive hash index pointer to page"
Account for a race condition when dropping the adaptive hash index
for a B-tree page.
btr_search_drop_page_hash_index(): Retry the operation if a hash index
with different parameters was built meanwhile. Add diagnostics for the
case that hash node pointers to the page remain.
btr_search_info_update_hash(), btr_search_info_update_slow():
Document the parameter "info" as in/out.
#16814: "SHOW INNODB STATUS format error in LATEST FOREIGN KEY ERROR
section"
Add a missing newline to the LAST FOREIGN KEY ERROR section in SHOW
INNODB STATUS output.
dict_foreign_error_report(): Always print a newline after invoking
dict_print_info_on_foreign_key_in_create_format().
#16827: "Better InnoDB error message if ibdata files omitted from my.cnf"
#17126: "CHECK TABLE on InnoDB causes a short hang during check of adaptive
hash"
CHECK TABLE blocking other queries, by releasing the btr_search_latch
periodically during the adaptive hash table validation.
#17405: "Valgrind: conditional jump or move depends on unititialised values"
buf_block_init(): Reset magic_n, buf_fix_count and io_fix to avoid
testing uninitialized variables.
2006-03-10 17:22:21 +01:00
|
|
|
que_node_t* res_word,/* in: function name reserved word */
|
2001-02-17 13:19:19 +01:00
|
|
|
que_node_t* arg); /* in: first argument in the argument list */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses an operator expression. */
|
|
|
|
|
|
|
|
func_node_t*
|
|
|
|
pars_op(
|
|
|
|
/*====*/
|
|
|
|
/* out, own: function node in a query tree */
|
|
|
|
int func, /* in: operator token code */
|
|
|
|
que_node_t* arg1, /* in: first argument */
|
|
|
|
que_node_t* arg2); /* in: second argument or NULL for an unary
|
|
|
|
operator */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses an ORDER BY clause. Order by a single column only is supported. */
|
|
|
|
|
|
|
|
order_node_t*
|
|
|
|
pars_order_by(
|
|
|
|
/*==========*/
|
|
|
|
/* out, own: order-by node in a query tree */
|
|
|
|
sym_node_t* column, /* in: column name */
|
|
|
|
pars_res_word_t* asc); /* in: &pars_asc_token or pars_desc_token */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a select list; creates a query graph node for the whole SELECT
|
|
|
|
statement. */
|
|
|
|
|
|
|
|
sel_node_t*
|
|
|
|
pars_select_list(
|
|
|
|
/*=============*/
|
|
|
|
/* out, own: select node in a query
|
|
|
|
tree */
|
|
|
|
que_node_t* select_list, /* in: select list */
|
|
|
|
sym_node_t* into_list); /* in: variables list or NULL */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a cursor declaration. */
|
|
|
|
|
|
|
|
que_node_t*
|
|
|
|
pars_cursor_declaration(
|
|
|
|
/*====================*/
|
|
|
|
/* out: sym_node */
|
|
|
|
sym_node_t* sym_node, /* in: cursor id node in the symbol
|
|
|
|
table */
|
|
|
|
sel_node_t* select_node); /* in: select node */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a select statement. */
|
|
|
|
|
|
|
|
sel_node_t*
|
|
|
|
pars_select_statement(
|
|
|
|
/*==================*/
|
|
|
|
/* out, own: select node in a query
|
|
|
|
tree */
|
|
|
|
sel_node_t* select_node, /* in: select node already containing
|
|
|
|
the select list */
|
|
|
|
sym_node_t* table_list, /* in: table list */
|
|
|
|
que_node_t* search_cond, /* in: search condition or NULL */
|
|
|
|
pars_res_word_t* for_update, /* in: NULL or &pars_update_token */
|
|
|
|
pars_res_word_t* consistent_read,/* in: NULL or
|
|
|
|
&pars_consistent_token */
|
|
|
|
order_node_t* order_by); /* in: NULL or an order-by node */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a column assignment in an update. */
|
|
|
|
|
|
|
|
col_assign_node_t*
|
|
|
|
pars_column_assignment(
|
|
|
|
/*===================*/
|
|
|
|
/* out: column assignment node */
|
|
|
|
sym_node_t* column, /* in: column to assign */
|
|
|
|
que_node_t* exp); /* in: value to assign */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a delete or update statement start. */
|
|
|
|
|
|
|
|
upd_node_t*
|
|
|
|
pars_update_statement_start(
|
|
|
|
/*========================*/
|
|
|
|
/* out, own: update node in a query
|
|
|
|
tree */
|
|
|
|
ibool is_delete, /* in: TRUE if delete */
|
|
|
|
sym_node_t* table_sym, /* in: table name node */
|
|
|
|
col_assign_node_t* col_assign_list);/* in: column assignment list, NULL
|
Applied innodb-5.1-ss269 snapshot.
Fixed BUGS:
#3300: "UPDATE statement with no index column in where condition locks
all rows"
Implement semi-consistent read to reduce lock conflicts at the cost
of breaking serializability.
ha_innobase::unlock_row(): reset the "did semi consistent read" flag
ha_innobase::was_semi_consistent_read(),
ha_innobase::try_semi_consistent_read(): new methods
row_prebuilt_t, row_create_prebuilt(): add field row_read_type for
keeping track of semi-consistent reads
row_vers_build_for_semi_consistent_read(),
row_sel_build_committed_vers_for_mysql(): new functions
row_search_for_mysql(): implement semi-consistent reads
#9802: "Foreign key checks disallow alter table".
Added test cases.
#12456: "Cursor shows incorrect data - DML does not affect,
probably caching"
This patch implements a high-granularity read view to be used with
cursors. In this high-granularity consistent read view modifications
done by the creating transaction after the cursor is created or
future transactions are not visible. But those modifications that
transaction did before the cursor was created are visible.
#12701: "Support >4GB buffer pool and log files on 64-bit Windows"
Do not call os_file_create_tmpfile() at runtime. Instead, create all
tempfiles at startup and guard access to them with mutexes.
#13778: "If FOREIGN_KEY_CHECKS=0, one can create inconsistent FOREIGN KEYs".
When FOREIGN_KEY_CHECKS=0 we still need to check that datatypes between
foreign key references are compatible.
#14189: "VARBINARY and BINARY variables: trailing space ignored with InnoDB"
innobase_init(): Assert that
DATA_MYSQL_BINARY_CHARSET_COLL == my_charset_bin.number.
dtype_get_pad_char(): Do not pad VARBINARY or BINARY columns.
row_ins_cascade_calc_update_vec(): Refuse ON UPDATE CASCADE when trying
to change the length of a VARBINARY column that refers to or is referenced
by a BINARY column. BINARY columns are no longer padded on comparison,
and thus they cannot be padded on storage either.
#14747: "Race condition can cause btr_search_drop_page_hash_index() to crash"
Note that buf_block_t::index should be protected by btr_search_latch
or an s-latch or x-latch on the index page.
btr_search_drop_page_hash_index(): Read block->index while holding
btr_search_latch and use the cached value in the loop. Remove some
redundant assertions.
#15108: "mysqld crashes when innodb_log_file_size is set > 4G"
#15308: "Problem of Order with Enum Column in Primary Key"
#15550: "mysqld crashes in printing a FOREIGN KEY error in InnoDB"
row_ins_foreign_report_add_err(): When printing the parent record,
use the index in the parent table rather than the index in the child table.
#15653: "Slow inserts to InnoDB if many thousands of .ibd files"
Keep track on unflushed modifications to file spaces. When there are tens
of thousands of file spaces, flushing all files in fil_flush_file_spaces()
would be very slow.
fil_flush_file_spaces(): Only flush unflushed file spaces.
fil_space_t, fil_system_t: Add a list of unflushed spaces.
#15991: "innodb-file-per-table + symlink database + rename = cr"
os_file_handle_error(): Map the error codes EXDEV, ENOTDIR, and EISDIR
to the new code OS_FILE_PATH_ERROR. Treat this code as OS_FILE_PATH_ERROR.
This fixes the crash on RENAME TABLE when the .ibd file is a symbolic link
to a different file system.
#16157: "InnoDB crashes when main location settings are empty"
This patch is from Heikki.
#16298: "InnoDB segfaults in INSERTs in upgrade of 4.0 -> 5.0 tables
with VARCHAR BINARY"
dict_load_columns(): Set the charset-collation code
DATA_MYSQL_BINARY_CHARSET_COLL for those binary string columns
that lack a charset-collation code, i.e., the tables were created
with an older version of MySQL/InnoDB than 4.1.2.
#16229: "MySQL/InnoDB uses full explicit table locks in trigger processing"
Take a InnoDB table lock only if user has explicitly requested a table
lock. Added some additional comments to store_lock() and external_lock().
#16387: "InnoDB crash when dropping a foreign key <table>_ibfk_0"
Do not mistake TABLENAME_ibfk_0 for auto-generated id.
dict_table_get_highest_foreign_id(): Ignore foreign constraint
identifiers starting with the pattern TABLENAME_ibfk_0.
#16582: "InnoDB: Error in an adaptive hash index pointer to page"
Account for a race condition when dropping the adaptive hash index
for a B-tree page.
btr_search_drop_page_hash_index(): Retry the operation if a hash index
with different parameters was built meanwhile. Add diagnostics for the
case that hash node pointers to the page remain.
btr_search_info_update_hash(), btr_search_info_update_slow():
Document the parameter "info" as in/out.
#16814: "SHOW INNODB STATUS format error in LATEST FOREIGN KEY ERROR
section"
Add a missing newline to the LAST FOREIGN KEY ERROR section in SHOW
INNODB STATUS output.
dict_foreign_error_report(): Always print a newline after invoking
dict_print_info_on_foreign_key_in_create_format().
#16827: "Better InnoDB error message if ibdata files omitted from my.cnf"
#17126: "CHECK TABLE on InnoDB causes a short hang during check of adaptive
hash"
CHECK TABLE blocking other queries, by releasing the btr_search_latch
periodically during the adaptive hash table validation.
#17405: "Valgrind: conditional jump or move depends on unititialised values"
buf_block_init(): Reset magic_n, buf_fix_count and io_fix to avoid
testing uninitialized variables.
2006-03-10 17:22:21 +01:00
|
|
|
if delete */
|
2001-02-17 13:19:19 +01:00
|
|
|
/*************************************************************************
|
|
|
|
Parses an update or delete statement. */
|
|
|
|
|
|
|
|
upd_node_t*
|
|
|
|
pars_update_statement(
|
|
|
|
/*==================*/
|
|
|
|
/* out, own: update node in a query
|
|
|
|
tree */
|
|
|
|
upd_node_t* node, /* in: update node */
|
|
|
|
sym_node_t* cursor_sym, /* in: pointer to a cursor entry in
|
|
|
|
the symbol table or NULL */
|
|
|
|
que_node_t* search_cond); /* in: search condition or NULL */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses an insert statement. */
|
|
|
|
|
|
|
|
ins_node_t*
|
|
|
|
pars_insert_statement(
|
|
|
|
/*==================*/
|
|
|
|
/* out, own: update node in a query
|
|
|
|
tree */
|
|
|
|
sym_node_t* table_sym, /* in: table name node */
|
Applied innodb-5.1-ss269 snapshot.
Fixed BUGS:
#3300: "UPDATE statement with no index column in where condition locks
all rows"
Implement semi-consistent read to reduce lock conflicts at the cost
of breaking serializability.
ha_innobase::unlock_row(): reset the "did semi consistent read" flag
ha_innobase::was_semi_consistent_read(),
ha_innobase::try_semi_consistent_read(): new methods
row_prebuilt_t, row_create_prebuilt(): add field row_read_type for
keeping track of semi-consistent reads
row_vers_build_for_semi_consistent_read(),
row_sel_build_committed_vers_for_mysql(): new functions
row_search_for_mysql(): implement semi-consistent reads
#9802: "Foreign key checks disallow alter table".
Added test cases.
#12456: "Cursor shows incorrect data - DML does not affect,
probably caching"
This patch implements a high-granularity read view to be used with
cursors. In this high-granularity consistent read view modifications
done by the creating transaction after the cursor is created or
future transactions are not visible. But those modifications that
transaction did before the cursor was created are visible.
#12701: "Support >4GB buffer pool and log files on 64-bit Windows"
Do not call os_file_create_tmpfile() at runtime. Instead, create all
tempfiles at startup and guard access to them with mutexes.
#13778: "If FOREIGN_KEY_CHECKS=0, one can create inconsistent FOREIGN KEYs".
When FOREIGN_KEY_CHECKS=0 we still need to check that datatypes between
foreign key references are compatible.
#14189: "VARBINARY and BINARY variables: trailing space ignored with InnoDB"
innobase_init(): Assert that
DATA_MYSQL_BINARY_CHARSET_COLL == my_charset_bin.number.
dtype_get_pad_char(): Do not pad VARBINARY or BINARY columns.
row_ins_cascade_calc_update_vec(): Refuse ON UPDATE CASCADE when trying
to change the length of a VARBINARY column that refers to or is referenced
by a BINARY column. BINARY columns are no longer padded on comparison,
and thus they cannot be padded on storage either.
#14747: "Race condition can cause btr_search_drop_page_hash_index() to crash"
Note that buf_block_t::index should be protected by btr_search_latch
or an s-latch or x-latch on the index page.
btr_search_drop_page_hash_index(): Read block->index while holding
btr_search_latch and use the cached value in the loop. Remove some
redundant assertions.
#15108: "mysqld crashes when innodb_log_file_size is set > 4G"
#15308: "Problem of Order with Enum Column in Primary Key"
#15550: "mysqld crashes in printing a FOREIGN KEY error in InnoDB"
row_ins_foreign_report_add_err(): When printing the parent record,
use the index in the parent table rather than the index in the child table.
#15653: "Slow inserts to InnoDB if many thousands of .ibd files"
Keep track on unflushed modifications to file spaces. When there are tens
of thousands of file spaces, flushing all files in fil_flush_file_spaces()
would be very slow.
fil_flush_file_spaces(): Only flush unflushed file spaces.
fil_space_t, fil_system_t: Add a list of unflushed spaces.
#15991: "innodb-file-per-table + symlink database + rename = cr"
os_file_handle_error(): Map the error codes EXDEV, ENOTDIR, and EISDIR
to the new code OS_FILE_PATH_ERROR. Treat this code as OS_FILE_PATH_ERROR.
This fixes the crash on RENAME TABLE when the .ibd file is a symbolic link
to a different file system.
#16157: "InnoDB crashes when main location settings are empty"
This patch is from Heikki.
#16298: "InnoDB segfaults in INSERTs in upgrade of 4.0 -> 5.0 tables
with VARCHAR BINARY"
dict_load_columns(): Set the charset-collation code
DATA_MYSQL_BINARY_CHARSET_COLL for those binary string columns
that lack a charset-collation code, i.e., the tables were created
with an older version of MySQL/InnoDB than 4.1.2.
#16229: "MySQL/InnoDB uses full explicit table locks in trigger processing"
Take a InnoDB table lock only if user has explicitly requested a table
lock. Added some additional comments to store_lock() and external_lock().
#16387: "InnoDB crash when dropping a foreign key <table>_ibfk_0"
Do not mistake TABLENAME_ibfk_0 for auto-generated id.
dict_table_get_highest_foreign_id(): Ignore foreign constraint
identifiers starting with the pattern TABLENAME_ibfk_0.
#16582: "InnoDB: Error in an adaptive hash index pointer to page"
Account for a race condition when dropping the adaptive hash index
for a B-tree page.
btr_search_drop_page_hash_index(): Retry the operation if a hash index
with different parameters was built meanwhile. Add diagnostics for the
case that hash node pointers to the page remain.
btr_search_info_update_hash(), btr_search_info_update_slow():
Document the parameter "info" as in/out.
#16814: "SHOW INNODB STATUS format error in LATEST FOREIGN KEY ERROR
section"
Add a missing newline to the LAST FOREIGN KEY ERROR section in SHOW
INNODB STATUS output.
dict_foreign_error_report(): Always print a newline after invoking
dict_print_info_on_foreign_key_in_create_format().
#16827: "Better InnoDB error message if ibdata files omitted from my.cnf"
#17126: "CHECK TABLE on InnoDB causes a short hang during check of adaptive
hash"
CHECK TABLE blocking other queries, by releasing the btr_search_latch
periodically during the adaptive hash table validation.
#17405: "Valgrind: conditional jump or move depends on unititialised values"
buf_block_init(): Reset magic_n, buf_fix_count and io_fix to avoid
testing uninitialized variables.
2006-03-10 17:22:21 +01:00
|
|
|
que_node_t* values_list, /* in: value expression list or NULL */
|
2001-02-17 13:19:19 +01:00
|
|
|
sel_node_t* select); /* in: select condition or NULL */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a procedure parameter declaration. */
|
|
|
|
|
|
|
|
sym_node_t*
|
|
|
|
pars_parameter_declaration(
|
|
|
|
/*=======================*/
|
|
|
|
/* out, own: symbol table node of type
|
|
|
|
SYM_VAR */
|
|
|
|
sym_node_t* node, /* in: symbol table node allocated for the
|
|
|
|
id of the parameter */
|
|
|
|
ulint param_type,
|
|
|
|
/* in: PARS_INPUT or PARS_OUTPUT */
|
|
|
|
pars_res_word_t* type); /* in: pointer to a type token */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses an elsif element. */
|
|
|
|
|
|
|
|
elsif_node_t*
|
|
|
|
pars_elsif_element(
|
|
|
|
/*===============*/
|
|
|
|
/* out: elsif node */
|
|
|
|
que_node_t* cond, /* in: if-condition */
|
|
|
|
que_node_t* stat_list); /* in: statement list */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses an if-statement. */
|
|
|
|
|
|
|
|
if_node_t*
|
|
|
|
pars_if_statement(
|
|
|
|
/*==============*/
|
|
|
|
/* out: if-statement node */
|
|
|
|
que_node_t* cond, /* in: if-condition */
|
|
|
|
que_node_t* stat_list, /* in: statement list */
|
|
|
|
que_node_t* else_part); /* in: else-part statement list */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a for-loop-statement. */
|
|
|
|
|
|
|
|
for_node_t*
|
|
|
|
pars_for_statement(
|
|
|
|
/*===============*/
|
|
|
|
/* out: for-statement node */
|
|
|
|
sym_node_t* loop_var, /* in: loop variable */
|
|
|
|
que_node_t* loop_start_limit,/* in: loop start expression */
|
|
|
|
que_node_t* loop_end_limit, /* in: loop end expression */
|
|
|
|
que_node_t* stat_list); /* in: statement list */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a while-statement. */
|
|
|
|
|
|
|
|
while_node_t*
|
|
|
|
pars_while_statement(
|
|
|
|
/*=================*/
|
|
|
|
/* out: while-statement node */
|
|
|
|
que_node_t* cond, /* in: while-condition */
|
|
|
|
que_node_t* stat_list); /* in: statement list */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a return-statement. */
|
|
|
|
|
|
|
|
return_node_t*
|
|
|
|
pars_return_statement(void);
|
|
|
|
/*=======================*/
|
|
|
|
/* out: return-statement node */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a procedure call. */
|
|
|
|
|
|
|
|
func_node_t*
|
|
|
|
pars_procedure_call(
|
|
|
|
/*================*/
|
|
|
|
/* out: function node */
|
|
|
|
que_node_t* res_word,/* in: procedure name reserved word */
|
|
|
|
que_node_t* args); /* in: argument list */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses an assignment statement. */
|
|
|
|
|
|
|
|
assign_node_t*
|
|
|
|
pars_assignment_statement(
|
|
|
|
/*======================*/
|
|
|
|
/* out: assignment statement node */
|
|
|
|
sym_node_t* var, /* in: variable to assign */
|
|
|
|
que_node_t* val); /* in: value to assign */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a fetch statement. */
|
|
|
|
|
|
|
|
fetch_node_t*
|
|
|
|
pars_fetch_statement(
|
|
|
|
/*=================*/
|
|
|
|
/* out: fetch statement node */
|
|
|
|
sym_node_t* cursor, /* in: cursor node */
|
|
|
|
sym_node_t* into_list); /* in: variables to set */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses an open or close cursor statement. */
|
|
|
|
|
|
|
|
open_node_t*
|
|
|
|
pars_open_statement(
|
|
|
|
/*================*/
|
|
|
|
/* out: fetch statement node */
|
|
|
|
ulint type, /* in: ROW_SEL_OPEN_CURSOR
|
|
|
|
or ROW_SEL_CLOSE_CURSOR */
|
|
|
|
sym_node_t* cursor); /* in: cursor node */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a row_printf-statement. */
|
|
|
|
|
|
|
|
row_printf_node_t*
|
|
|
|
pars_row_printf_statement(
|
|
|
|
/*======================*/
|
|
|
|
/* out: row_printf-statement node */
|
|
|
|
sel_node_t* sel_node); /* in: select node */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a commit statement. */
|
|
|
|
|
|
|
|
commit_node_t*
|
|
|
|
pars_commit_statement(void);
|
|
|
|
/*=======================*/
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a rollback statement. */
|
|
|
|
|
|
|
|
roll_node_t*
|
|
|
|
pars_rollback_statement(void);
|
|
|
|
/*=========================*/
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a column definition at a table creation. */
|
|
|
|
|
|
|
|
sym_node_t*
|
|
|
|
pars_column_def(
|
|
|
|
/*============*/
|
Applied innodb-5.1-ss269 snapshot.
Fixed BUGS:
#3300: "UPDATE statement with no index column in where condition locks
all rows"
Implement semi-consistent read to reduce lock conflicts at the cost
of breaking serializability.
ha_innobase::unlock_row(): reset the "did semi consistent read" flag
ha_innobase::was_semi_consistent_read(),
ha_innobase::try_semi_consistent_read(): new methods
row_prebuilt_t, row_create_prebuilt(): add field row_read_type for
keeping track of semi-consistent reads
row_vers_build_for_semi_consistent_read(),
row_sel_build_committed_vers_for_mysql(): new functions
row_search_for_mysql(): implement semi-consistent reads
#9802: "Foreign key checks disallow alter table".
Added test cases.
#12456: "Cursor shows incorrect data - DML does not affect,
probably caching"
This patch implements a high-granularity read view to be used with
cursors. In this high-granularity consistent read view modifications
done by the creating transaction after the cursor is created or
future transactions are not visible. But those modifications that
transaction did before the cursor was created are visible.
#12701: "Support >4GB buffer pool and log files on 64-bit Windows"
Do not call os_file_create_tmpfile() at runtime. Instead, create all
tempfiles at startup and guard access to them with mutexes.
#13778: "If FOREIGN_KEY_CHECKS=0, one can create inconsistent FOREIGN KEYs".
When FOREIGN_KEY_CHECKS=0 we still need to check that datatypes between
foreign key references are compatible.
#14189: "VARBINARY and BINARY variables: trailing space ignored with InnoDB"
innobase_init(): Assert that
DATA_MYSQL_BINARY_CHARSET_COLL == my_charset_bin.number.
dtype_get_pad_char(): Do not pad VARBINARY or BINARY columns.
row_ins_cascade_calc_update_vec(): Refuse ON UPDATE CASCADE when trying
to change the length of a VARBINARY column that refers to or is referenced
by a BINARY column. BINARY columns are no longer padded on comparison,
and thus they cannot be padded on storage either.
#14747: "Race condition can cause btr_search_drop_page_hash_index() to crash"
Note that buf_block_t::index should be protected by btr_search_latch
or an s-latch or x-latch on the index page.
btr_search_drop_page_hash_index(): Read block->index while holding
btr_search_latch and use the cached value in the loop. Remove some
redundant assertions.
#15108: "mysqld crashes when innodb_log_file_size is set > 4G"
#15308: "Problem of Order with Enum Column in Primary Key"
#15550: "mysqld crashes in printing a FOREIGN KEY error in InnoDB"
row_ins_foreign_report_add_err(): When printing the parent record,
use the index in the parent table rather than the index in the child table.
#15653: "Slow inserts to InnoDB if many thousands of .ibd files"
Keep track on unflushed modifications to file spaces. When there are tens
of thousands of file spaces, flushing all files in fil_flush_file_spaces()
would be very slow.
fil_flush_file_spaces(): Only flush unflushed file spaces.
fil_space_t, fil_system_t: Add a list of unflushed spaces.
#15991: "innodb-file-per-table + symlink database + rename = cr"
os_file_handle_error(): Map the error codes EXDEV, ENOTDIR, and EISDIR
to the new code OS_FILE_PATH_ERROR. Treat this code as OS_FILE_PATH_ERROR.
This fixes the crash on RENAME TABLE when the .ibd file is a symbolic link
to a different file system.
#16157: "InnoDB crashes when main location settings are empty"
This patch is from Heikki.
#16298: "InnoDB segfaults in INSERTs in upgrade of 4.0 -> 5.0 tables
with VARCHAR BINARY"
dict_load_columns(): Set the charset-collation code
DATA_MYSQL_BINARY_CHARSET_COLL for those binary string columns
that lack a charset-collation code, i.e., the tables were created
with an older version of MySQL/InnoDB than 4.1.2.
#16229: "MySQL/InnoDB uses full explicit table locks in trigger processing"
Take a InnoDB table lock only if user has explicitly requested a table
lock. Added some additional comments to store_lock() and external_lock().
#16387: "InnoDB crash when dropping a foreign key <table>_ibfk_0"
Do not mistake TABLENAME_ibfk_0 for auto-generated id.
dict_table_get_highest_foreign_id(): Ignore foreign constraint
identifiers starting with the pattern TABLENAME_ibfk_0.
#16582: "InnoDB: Error in an adaptive hash index pointer to page"
Account for a race condition when dropping the adaptive hash index
for a B-tree page.
btr_search_drop_page_hash_index(): Retry the operation if a hash index
with different parameters was built meanwhile. Add diagnostics for the
case that hash node pointers to the page remain.
btr_search_info_update_hash(), btr_search_info_update_slow():
Document the parameter "info" as in/out.
#16814: "SHOW INNODB STATUS format error in LATEST FOREIGN KEY ERROR
section"
Add a missing newline to the LAST FOREIGN KEY ERROR section in SHOW
INNODB STATUS output.
dict_foreign_error_report(): Always print a newline after invoking
dict_print_info_on_foreign_key_in_create_format().
#16827: "Better InnoDB error message if ibdata files omitted from my.cnf"
#17126: "CHECK TABLE on InnoDB causes a short hang during check of adaptive
hash"
CHECK TABLE blocking other queries, by releasing the btr_search_latch
periodically during the adaptive hash table validation.
#17405: "Valgrind: conditional jump or move depends on unititialised values"
buf_block_init(): Reset magic_n, buf_fix_count and io_fix to avoid
testing uninitialized variables.
2006-03-10 17:22:21 +01:00
|
|
|
/* out: column sym table
|
|
|
|
node */
|
|
|
|
sym_node_t* sym_node, /* in: column node in the
|
|
|
|
symbol table */
|
|
|
|
pars_res_word_t* type, /* in: data type */
|
|
|
|
sym_node_t* len, /* in: length of column, or
|
|
|
|
NULL */
|
|
|
|
void* is_not_null); /* in: if not NULL, column
|
|
|
|
is of type NOT NULL. */
|
2001-02-17 13:19:19 +01:00
|
|
|
/*************************************************************************
|
|
|
|
Parses a table creation operation. */
|
|
|
|
|
|
|
|
tab_node_t*
|
|
|
|
pars_create_table(
|
|
|
|
/*==============*/
|
|
|
|
/* out: table create subgraph */
|
|
|
|
sym_node_t* table_sym, /* in: table name node in the symbol
|
|
|
|
table */
|
|
|
|
sym_node_t* column_defs, /* in: list of column names */
|
|
|
|
void* not_fit_in_memory);/* in: a non-NULL pointer means that
|
|
|
|
this is a table which in simulations
|
|
|
|
should be simulated as not fitting
|
|
|
|
in memory; thread is put to sleep
|
|
|
|
to simulate disk accesses; NOTE that
|
|
|
|
this flag is not stored to the data
|
|
|
|
dictionary on disk, and the database
|
|
|
|
will forget about non-NULL value if
|
|
|
|
it has to reload the table definition
|
|
|
|
from disk */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses an index creation operation. */
|
|
|
|
|
|
|
|
ind_node_t*
|
|
|
|
pars_create_index(
|
|
|
|
/*==============*/
|
|
|
|
/* out: index create subgraph */
|
|
|
|
pars_res_word_t* unique_def, /* in: not NULL if a unique index */
|
|
|
|
pars_res_word_t* clustered_def, /* in: not NULL if a clustered index */
|
|
|
|
sym_node_t* index_sym, /* in: index name node in the symbol
|
|
|
|
table */
|
|
|
|
sym_node_t* table_sym, /* in: table name node in the symbol
|
|
|
|
table */
|
|
|
|
sym_node_t* column_list); /* in: list of column names */
|
|
|
|
/*************************************************************************
|
|
|
|
Parses a procedure definition. */
|
|
|
|
|
|
|
|
que_fork_t*
|
|
|
|
pars_procedure_definition(
|
|
|
|
/*======================*/
|
|
|
|
/* out: query fork node */
|
|
|
|
sym_node_t* sym_node, /* in: procedure id node in the symbol
|
|
|
|
table */
|
|
|
|
sym_node_t* param_list, /* in: parameter declaration list */
|
|
|
|
que_node_t* stat_list); /* in: statement list */
|
|
|
|
|
|
|
|
/*****************************************************************
|
|
|
|
Parses a stored procedure call, when this is not within another stored
|
2004-03-11 15:36:19 +01:00
|
|
|
procedure, that is, the client issues a procedure call directly.
|
|
|
|
In MySQL/InnoDB, stored InnoDB procedures are invoked via the
|
|
|
|
parsed procedure tree, not via InnoDB SQL, so this function is not used. */
|
2001-02-17 13:19:19 +01:00
|
|
|
|
|
|
|
que_fork_t*
|
|
|
|
pars_stored_procedure_call(
|
|
|
|
/*=======================*/
|
|
|
|
/* out: query graph */
|
|
|
|
sym_node_t* sym_node); /* in: stored procedure name */
|
|
|
|
/**********************************************************************
|
|
|
|
Completes a query graph by adding query thread and fork nodes
|
|
|
|
above it and prepares the graph for running. The fork created is of
|
|
|
|
type QUE_FORK_MYSQL_INTERFACE. */
|
|
|
|
|
|
|
|
que_thr_t*
|
|
|
|
pars_complete_graph_for_exec(
|
|
|
|
/*=========================*/
|
|
|
|
/* out: query thread node to run */
|
|
|
|
que_node_t* node, /* in: root node for an incomplete
|
|
|
|
query graph */
|
|
|
|
trx_t* trx, /* in: transaction handle */
|
|
|
|
mem_heap_t* heap); /* in: memory heap from which allocated */
|
|
|
|
|
|
|
|
|
|
|
|
/* Struct used to denote a reserved word in a parsing tree */
|
|
|
|
struct pars_res_word_struct{
|
2005-03-07 11:03:33 +01:00
|
|
|
int code; /* the token code for the reserved word from
|
2001-02-17 13:19:19 +01:00
|
|
|
pars0grm.h */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* A predefined function or operator node in a parsing tree; this construct
|
|
|
|
is also used for some non-functions like the assignment ':=' */
|
|
|
|
struct func_node_struct{
|
|
|
|
que_common_t common; /* type: QUE_NODE_FUNC */
|
|
|
|
int func; /* token code of the function name */
|
|
|
|
ulint class; /* class of the function */
|
|
|
|
que_node_t* args; /* argument(s) of the function */
|
|
|
|
UT_LIST_NODE_T(func_node_t) cond_list;
|
|
|
|
/* list of comparison conditions; defined
|
|
|
|
only for comparison operator nodes except,
|
|
|
|
presently, for OPT_SCROLL_TYPE ones */
|
|
|
|
UT_LIST_NODE_T(func_node_t) func_node_list;
|
|
|
|
/* list of function nodes in a parsed
|
|
|
|
query graph */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* An order-by node in a select */
|
|
|
|
struct order_node_struct{
|
|
|
|
que_common_t common; /* type: QUE_NODE_ORDER */
|
|
|
|
sym_node_t* column; /* order-by column */
|
|
|
|
ibool asc; /* TRUE if ascending, FALSE if descending */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Procedure definition node */
|
|
|
|
struct proc_node_struct{
|
|
|
|
que_common_t common; /* type: QUE_NODE_PROC */
|
|
|
|
sym_node_t* proc_id; /* procedure name symbol in the symbol
|
|
|
|
table of this same procedure */
|
|
|
|
sym_node_t* param_list; /* input and output parameters */
|
|
|
|
que_node_t* stat_list; /* statement list */
|
|
|
|
sym_tab_t* sym_tab; /* symbol table of this procedure */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* elsif-element node */
|
|
|
|
struct elsif_node_struct{
|
|
|
|
que_common_t common; /* type: QUE_NODE_ELSIF */
|
|
|
|
que_node_t* cond; /* if condition */
|
|
|
|
que_node_t* stat_list; /* statement list */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* if-statement node */
|
|
|
|
struct if_node_struct{
|
|
|
|
que_common_t common; /* type: QUE_NODE_IF */
|
|
|
|
que_node_t* cond; /* if condition */
|
|
|
|
que_node_t* stat_list; /* statement list */
|
|
|
|
que_node_t* else_part; /* else-part statement list */
|
Applied innodb-5.1-ss269 snapshot.
Fixed BUGS:
#3300: "UPDATE statement with no index column in where condition locks
all rows"
Implement semi-consistent read to reduce lock conflicts at the cost
of breaking serializability.
ha_innobase::unlock_row(): reset the "did semi consistent read" flag
ha_innobase::was_semi_consistent_read(),
ha_innobase::try_semi_consistent_read(): new methods
row_prebuilt_t, row_create_prebuilt(): add field row_read_type for
keeping track of semi-consistent reads
row_vers_build_for_semi_consistent_read(),
row_sel_build_committed_vers_for_mysql(): new functions
row_search_for_mysql(): implement semi-consistent reads
#9802: "Foreign key checks disallow alter table".
Added test cases.
#12456: "Cursor shows incorrect data - DML does not affect,
probably caching"
This patch implements a high-granularity read view to be used with
cursors. In this high-granularity consistent read view modifications
done by the creating transaction after the cursor is created or
future transactions are not visible. But those modifications that
transaction did before the cursor was created are visible.
#12701: "Support >4GB buffer pool and log files on 64-bit Windows"
Do not call os_file_create_tmpfile() at runtime. Instead, create all
tempfiles at startup and guard access to them with mutexes.
#13778: "If FOREIGN_KEY_CHECKS=0, one can create inconsistent FOREIGN KEYs".
When FOREIGN_KEY_CHECKS=0 we still need to check that datatypes between
foreign key references are compatible.
#14189: "VARBINARY and BINARY variables: trailing space ignored with InnoDB"
innobase_init(): Assert that
DATA_MYSQL_BINARY_CHARSET_COLL == my_charset_bin.number.
dtype_get_pad_char(): Do not pad VARBINARY or BINARY columns.
row_ins_cascade_calc_update_vec(): Refuse ON UPDATE CASCADE when trying
to change the length of a VARBINARY column that refers to or is referenced
by a BINARY column. BINARY columns are no longer padded on comparison,
and thus they cannot be padded on storage either.
#14747: "Race condition can cause btr_search_drop_page_hash_index() to crash"
Note that buf_block_t::index should be protected by btr_search_latch
or an s-latch or x-latch on the index page.
btr_search_drop_page_hash_index(): Read block->index while holding
btr_search_latch and use the cached value in the loop. Remove some
redundant assertions.
#15108: "mysqld crashes when innodb_log_file_size is set > 4G"
#15308: "Problem of Order with Enum Column in Primary Key"
#15550: "mysqld crashes in printing a FOREIGN KEY error in InnoDB"
row_ins_foreign_report_add_err(): When printing the parent record,
use the index in the parent table rather than the index in the child table.
#15653: "Slow inserts to InnoDB if many thousands of .ibd files"
Keep track on unflushed modifications to file spaces. When there are tens
of thousands of file spaces, flushing all files in fil_flush_file_spaces()
would be very slow.
fil_flush_file_spaces(): Only flush unflushed file spaces.
fil_space_t, fil_system_t: Add a list of unflushed spaces.
#15991: "innodb-file-per-table + symlink database + rename = cr"
os_file_handle_error(): Map the error codes EXDEV, ENOTDIR, and EISDIR
to the new code OS_FILE_PATH_ERROR. Treat this code as OS_FILE_PATH_ERROR.
This fixes the crash on RENAME TABLE when the .ibd file is a symbolic link
to a different file system.
#16157: "InnoDB crashes when main location settings are empty"
This patch is from Heikki.
#16298: "InnoDB segfaults in INSERTs in upgrade of 4.0 -> 5.0 tables
with VARCHAR BINARY"
dict_load_columns(): Set the charset-collation code
DATA_MYSQL_BINARY_CHARSET_COLL for those binary string columns
that lack a charset-collation code, i.e., the tables were created
with an older version of MySQL/InnoDB than 4.1.2.
#16229: "MySQL/InnoDB uses full explicit table locks in trigger processing"
Take a InnoDB table lock only if user has explicitly requested a table
lock. Added some additional comments to store_lock() and external_lock().
#16387: "InnoDB crash when dropping a foreign key <table>_ibfk_0"
Do not mistake TABLENAME_ibfk_0 for auto-generated id.
dict_table_get_highest_foreign_id(): Ignore foreign constraint
identifiers starting with the pattern TABLENAME_ibfk_0.
#16582: "InnoDB: Error in an adaptive hash index pointer to page"
Account for a race condition when dropping the adaptive hash index
for a B-tree page.
btr_search_drop_page_hash_index(): Retry the operation if a hash index
with different parameters was built meanwhile. Add diagnostics for the
case that hash node pointers to the page remain.
btr_search_info_update_hash(), btr_search_info_update_slow():
Document the parameter "info" as in/out.
#16814: "SHOW INNODB STATUS format error in LATEST FOREIGN KEY ERROR
section"
Add a missing newline to the LAST FOREIGN KEY ERROR section in SHOW
INNODB STATUS output.
dict_foreign_error_report(): Always print a newline after invoking
dict_print_info_on_foreign_key_in_create_format().
#16827: "Better InnoDB error message if ibdata files omitted from my.cnf"
#17126: "CHECK TABLE on InnoDB causes a short hang during check of adaptive
hash"
CHECK TABLE blocking other queries, by releasing the btr_search_latch
periodically during the adaptive hash table validation.
#17405: "Valgrind: conditional jump or move depends on unititialised values"
buf_block_init(): Reset magic_n, buf_fix_count and io_fix to avoid
testing uninitialized variables.
2006-03-10 17:22:21 +01:00
|
|
|
elsif_node_t* elsif_list; /* elsif element list */
|
2001-02-17 13:19:19 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
/* while-statement node */
|
|
|
|
struct while_node_struct{
|
|
|
|
que_common_t common; /* type: QUE_NODE_WHILE */
|
|
|
|
que_node_t* cond; /* while condition */
|
|
|
|
que_node_t* stat_list; /* statement list */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* for-loop-statement node */
|
|
|
|
struct for_node_struct{
|
|
|
|
que_common_t common; /* type: QUE_NODE_FOR */
|
|
|
|
sym_node_t* loop_var; /* loop variable: this is the
|
|
|
|
dereferenced symbol from the
|
|
|
|
variable declarations, not the
|
|
|
|
symbol occurrence in the for loop
|
|
|
|
definition */
|
|
|
|
que_node_t* loop_start_limit;/* initial value of loop variable */
|
|
|
|
que_node_t* loop_end_limit; /* end value of loop variable */
|
|
|
|
int loop_end_value; /* evaluated value for the end value:
|
|
|
|
it is calculated only when the loop
|
|
|
|
is entered, and will not change within
|
|
|
|
the loop */
|
|
|
|
que_node_t* stat_list; /* statement list */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* return-statement node */
|
|
|
|
struct return_node_struct{
|
|
|
|
que_common_t common; /* type: QUE_NODE_RETURN */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Assignment statement node */
|
|
|
|
struct assign_node_struct{
|
|
|
|
que_common_t common; /* type: QUE_NODE_ASSIGNMENT */
|
|
|
|
sym_node_t* var; /* variable to set */
|
|
|
|
que_node_t* val; /* value to assign */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Column assignment node */
|
|
|
|
struct col_assign_node_struct{
|
|
|
|
que_common_t common; /* type: QUE_NODE_COL_ASSIGN */
|
|
|
|
sym_node_t* col; /* column to set */
|
|
|
|
que_node_t* val; /* value to assign */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Classes of functions */
|
|
|
|
#define PARS_FUNC_ARITH 1 /* +, -, *, / */
|
|
|
|
#define PARS_FUNC_LOGICAL 2
|
|
|
|
#define PARS_FUNC_CMP 3
|
|
|
|
#define PARS_FUNC_PREDEFINED 4 /* TO_NUMBER, SUBSTR, ... */
|
|
|
|
#define PARS_FUNC_AGGREGATE 5 /* COUNT, DISTINCT, SUM */
|
|
|
|
#define PARS_FUNC_OTHER 6 /* these are not real functions,
|
|
|
|
e.g., := */
|
|
|
|
|
|
|
|
#ifndef UNIV_NONINL
|
|
|
|
#include "pars0pars.ic"
|
|
|
|
#endif
|
|
|
|
|
Applied innodb-5.1-ss269 snapshot.
Fixed BUGS:
#3300: "UPDATE statement with no index column in where condition locks
all rows"
Implement semi-consistent read to reduce lock conflicts at the cost
of breaking serializability.
ha_innobase::unlock_row(): reset the "did semi consistent read" flag
ha_innobase::was_semi_consistent_read(),
ha_innobase::try_semi_consistent_read(): new methods
row_prebuilt_t, row_create_prebuilt(): add field row_read_type for
keeping track of semi-consistent reads
row_vers_build_for_semi_consistent_read(),
row_sel_build_committed_vers_for_mysql(): new functions
row_search_for_mysql(): implement semi-consistent reads
#9802: "Foreign key checks disallow alter table".
Added test cases.
#12456: "Cursor shows incorrect data - DML does not affect,
probably caching"
This patch implements a high-granularity read view to be used with
cursors. In this high-granularity consistent read view modifications
done by the creating transaction after the cursor is created or
future transactions are not visible. But those modifications that
transaction did before the cursor was created are visible.
#12701: "Support >4GB buffer pool and log files on 64-bit Windows"
Do not call os_file_create_tmpfile() at runtime. Instead, create all
tempfiles at startup and guard access to them with mutexes.
#13778: "If FOREIGN_KEY_CHECKS=0, one can create inconsistent FOREIGN KEYs".
When FOREIGN_KEY_CHECKS=0 we still need to check that datatypes between
foreign key references are compatible.
#14189: "VARBINARY and BINARY variables: trailing space ignored with InnoDB"
innobase_init(): Assert that
DATA_MYSQL_BINARY_CHARSET_COLL == my_charset_bin.number.
dtype_get_pad_char(): Do not pad VARBINARY or BINARY columns.
row_ins_cascade_calc_update_vec(): Refuse ON UPDATE CASCADE when trying
to change the length of a VARBINARY column that refers to or is referenced
by a BINARY column. BINARY columns are no longer padded on comparison,
and thus they cannot be padded on storage either.
#14747: "Race condition can cause btr_search_drop_page_hash_index() to crash"
Note that buf_block_t::index should be protected by btr_search_latch
or an s-latch or x-latch on the index page.
btr_search_drop_page_hash_index(): Read block->index while holding
btr_search_latch and use the cached value in the loop. Remove some
redundant assertions.
#15108: "mysqld crashes when innodb_log_file_size is set > 4G"
#15308: "Problem of Order with Enum Column in Primary Key"
#15550: "mysqld crashes in printing a FOREIGN KEY error in InnoDB"
row_ins_foreign_report_add_err(): When printing the parent record,
use the index in the parent table rather than the index in the child table.
#15653: "Slow inserts to InnoDB if many thousands of .ibd files"
Keep track on unflushed modifications to file spaces. When there are tens
of thousands of file spaces, flushing all files in fil_flush_file_spaces()
would be very slow.
fil_flush_file_spaces(): Only flush unflushed file spaces.
fil_space_t, fil_system_t: Add a list of unflushed spaces.
#15991: "innodb-file-per-table + symlink database + rename = cr"
os_file_handle_error(): Map the error codes EXDEV, ENOTDIR, and EISDIR
to the new code OS_FILE_PATH_ERROR. Treat this code as OS_FILE_PATH_ERROR.
This fixes the crash on RENAME TABLE when the .ibd file is a symbolic link
to a different file system.
#16157: "InnoDB crashes when main location settings are empty"
This patch is from Heikki.
#16298: "InnoDB segfaults in INSERTs in upgrade of 4.0 -> 5.0 tables
with VARCHAR BINARY"
dict_load_columns(): Set the charset-collation code
DATA_MYSQL_BINARY_CHARSET_COLL for those binary string columns
that lack a charset-collation code, i.e., the tables were created
with an older version of MySQL/InnoDB than 4.1.2.
#16229: "MySQL/InnoDB uses full explicit table locks in trigger processing"
Take a InnoDB table lock only if user has explicitly requested a table
lock. Added some additional comments to store_lock() and external_lock().
#16387: "InnoDB crash when dropping a foreign key <table>_ibfk_0"
Do not mistake TABLENAME_ibfk_0 for auto-generated id.
dict_table_get_highest_foreign_id(): Ignore foreign constraint
identifiers starting with the pattern TABLENAME_ibfk_0.
#16582: "InnoDB: Error in an adaptive hash index pointer to page"
Account for a race condition when dropping the adaptive hash index
for a B-tree page.
btr_search_drop_page_hash_index(): Retry the operation if a hash index
with different parameters was built meanwhile. Add diagnostics for the
case that hash node pointers to the page remain.
btr_search_info_update_hash(), btr_search_info_update_slow():
Document the parameter "info" as in/out.
#16814: "SHOW INNODB STATUS format error in LATEST FOREIGN KEY ERROR
section"
Add a missing newline to the LAST FOREIGN KEY ERROR section in SHOW
INNODB STATUS output.
dict_foreign_error_report(): Always print a newline after invoking
dict_print_info_on_foreign_key_in_create_format().
#16827: "Better InnoDB error message if ibdata files omitted from my.cnf"
#17126: "CHECK TABLE on InnoDB causes a short hang during check of adaptive
hash"
CHECK TABLE blocking other queries, by releasing the btr_search_latch
periodically during the adaptive hash table validation.
#17405: "Valgrind: conditional jump or move depends on unititialised values"
buf_block_init(): Reset magic_n, buf_fix_count and io_fix to avoid
testing uninitialized variables.
2006-03-10 17:22:21 +01:00
|
|
|
#endif
|