mariadb/include/mysql
Marko Mäkelä 0381921e26 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 commit d0ef1aaf61,
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 commit 8777458a6e 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
2024-02-08 10:35:45 +02:00
..
psi Merge branch 'merge-perfschema-5.7' into 10.5 2023-04-28 08:22:17 +02:00
auth_dialog_client.h
client_plugin.h
client_plugin.h.pp
plugin.h
plugin_audit.h
plugin_audit.h.pp Merge branch '10.4' into 10.5 2023-12-02 01:02:50 +01:00
plugin_auth.h
plugin_auth.h.pp Merge branch '10.4' into 10.5 2023-12-02 01:02:50 +01:00
plugin_auth_common.h
plugin_data_type.h
plugin_data_type.h.pp Merge branch '10.4' into 10.5 2023-12-02 01:02:50 +01:00
plugin_encryption.h
plugin_encryption.h.pp Merge branch '10.4' into 10.5 2023-12-02 01:02:50 +01:00
plugin_ftparser.h
plugin_ftparser.h.pp Merge branch '10.4' into 10.5 2023-12-02 01:02:50 +01:00
plugin_function.h
plugin_function.h.pp Merge branch '10.4' into 10.5 2023-12-02 01:02:50 +01:00
plugin_password_validation.h
plugin_password_validation.h.pp Merge branch '10.4' into 10.5 2023-12-02 01:02:50 +01:00
service_base64.h
service_debug_sync.h
service_encryption.h post fix for "move alloca() definition from all *.h files to one new header file" 2023-03-08 17:36:36 +01:00
service_encryption_scheme.h
service_json.h
service_kill_statement.h
service_logger.h
service_md5.h
service_my_crypt.h post-merge fix 2023-09-13 12:10:43 +02:00
service_my_print_error.h
service_my_snprintf.h
service_print_check_msg.h MDEV-33277 In-place upgrade causes invalid AUTO_INCREMENT values 2024-02-08 10:35:45 +02:00
service_progress_report.h
service_sha1.h
service_sha2.h
service_sql.h MDEV-27295 Backport SQL service, introduced by MDEV-19275. 2023-11-05 23:35:32 +04:00
service_thd_alloc.h
service_thd_autoinc.h
service_thd_error_context.h
service_thd_mdl.h
service_thd_rnd.h
service_thd_specifics.h
service_thd_timezone.h
service_thd_wait.h
service_wsrep.h MDEV-31905 GTID inconsistency 2023-12-22 00:10:23 +01:00
services.h MDEV-27595 Backport SQL service, introduced by MDEV-19275. 2023-11-05 23:35:31 +04:00