mirror of
https://github.com/MariaDB/server.git
synced 2025-07-18 23:03:28 +03:00
MDEV-33277 In-place upgrade causes invalid AUTO_INCREMENT values
MDEV-33308 CHECK TABLE is modifying .frm file even if --read-only As noted in commitd0ef1aaf61
, MySQL as well as older versions of MariaDB server would during ALTER TABLE ... IMPORT TABLESPACE write bogus values to the PAGE_MAX_TRX_ID field to pages of the clustered index, instead of letting that field remain 0. In commit8777458a6e
this field was repurposed for PAGE_ROOT_AUTO_INC in the clustered index root page. To avoid trouble when upgrading from MySQL or older versions of MariaDB, we will try to detect and correct bogus values of PAGE_ROOT_AUTO_INC when opening a table for the first time from the SQL layer. btr_read_autoinc_with_fallback(): Add the parameters to mysql_version,max to indicate the TABLE_SHARE::mysql_version of the .frm file and the maximum value allowed for the type of the AUTO_INCREMENT column. In case the table was originally created in MySQL or an older version of MariaDB, read also the maximum value of the AUTO_INCREMENT column from the table and reset the PAGE_ROOT_AUTO_INC if it is above the limit. dict_table_t::get_index(const dict_col_t &) const: Find an index that starts with the specified column. ha_innobase::check_for_upgrade(): Return HA_ADMIN_FAILED if InnoDB needs upgrading but is in read-only mode. In this way, the call to update_frm_version() will be skipped. row_import_autoinc(): Adjust the AUTO_INCREMENT column at the end of ALTER TABLE...IMPORT TABLESPACE. This refinement was suggested by Debarun Banerjee. The changes outside InnoDB were developed by Michael 'Monty' Widenius: Added print_check_msg() service for easy reporting of check/repair messages in ENGINE=Aria and ENGINE=InnoDB. Fixed that CHECK TABLE do not update the .frm file under --read-only. Added 'handler_flags' to HA_CHECK_OPT as a way for storage engines to store state from handler::check_for_upgrade(). Reviewed by: Debarun Banerjee
This commit is contained in:
@ -5665,6 +5665,40 @@ extern "C" void *thd_mdl_context(MYSQL_THD thd)
|
||||
return &thd->mdl_context;
|
||||
}
|
||||
|
||||
/**
|
||||
Send check/repair message to the user
|
||||
|
||||
@param op one of check or repair
|
||||
@param msg_type one of info, warning or error
|
||||
@param print_to_log <> 0 if we should also print the message to error log.
|
||||
*/
|
||||
|
||||
extern "C" void
|
||||
print_check_msg(THD *thd, const char *db_name, const char *table_name, const char *op,
|
||||
const char *msg_type, const char *message, my_bool print_to_log)
|
||||
{
|
||||
char name[NAME_LEN * 2 + 2];
|
||||
Protocol *protocol= thd->protocol;
|
||||
|
||||
DBUG_ASSERT(strlen(db_name) <= NAME_LEN);
|
||||
DBUG_ASSERT(strlen(table_name) <= NAME_LEN);
|
||||
|
||||
size_t length= size_t(strxnmov(name, sizeof name - 1,
|
||||
db_name, ".", table_name, NullS) -
|
||||
name);
|
||||
protocol->prepare_for_resend();
|
||||
protocol->store(name, length, system_charset_info);
|
||||
protocol->store(op, system_charset_info);
|
||||
protocol->store(msg_type, system_charset_info);
|
||||
protocol->store(message, system_charset_info);
|
||||
if (protocol->write())
|
||||
sql_print_error("Failed on my_net_write, writing to stderr instead: %s: %s\n",
|
||||
table_name, message);
|
||||
else if (thd->variables.log_warnings > 2 && print_to_log)
|
||||
sql_print_error("%s: table '%s' got '%s' during %s",
|
||||
msg_type, table_name, message, op);
|
||||
}
|
||||
|
||||
|
||||
/****************************************************************************
|
||||
Handling of statement states in functions and triggers.
|
||||
|
Reference in New Issue
Block a user