mirror of
https://github.com/MariaDB/server.git
synced 2025-01-18 13:02:28 +01:00
Merge mskold@bk-internal.mysql.com:/home/bk/mysql-5.1
into mysql.com:/home/marty/MySQL/mysql-5.1
This commit is contained in:
commit
c70ed99f48
2 changed files with 12 additions and 0 deletions
|
@ -28,6 +28,9 @@
|
|||
#ifndef yaSSL_NEW_HPP
|
||||
#define yaSSL_NEW_HPP
|
||||
|
||||
#ifdef HAVE_CONFIG_H
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#ifdef __sun
|
||||
|
||||
|
|
|
@ -4709,6 +4709,14 @@ static uint compare_tables(TABLE *table, List<create_field> *create_list,
|
|||
At the moment we can't handle altering temporary tables without a copy.
|
||||
We also test if OPTIMIZE TABLE was given and was mapped to alter table.
|
||||
In that case we always do full copy.
|
||||
|
||||
There was a bug prior to mysql-4.0.25. Number of null fields was
|
||||
calculated incorrectly. As a result frm and data files gets out of
|
||||
sync after fast alter table. There is no way to determine by which
|
||||
mysql version (in 4.0 and 4.1 branches) table was created, thus we
|
||||
disable fast alter table for all tables created by mysql versions
|
||||
prior to 5.0 branch.
|
||||
See BUG#6236.
|
||||
*/
|
||||
if (table->s->fields != create_list->elements ||
|
||||
table->s->db_type != create_info->db_type ||
|
||||
|
@ -4718,6 +4726,7 @@ static uint compare_tables(TABLE *table, List<create_field> *create_list,
|
|||
create_info->used_fields & HA_CREATE_USED_DEFAULT_CHARSET ||
|
||||
(alter_info->flags & (ALTER_RECREATE | ALTER_FOREIGN_KEY)) ||
|
||||
order_num ||
|
||||
!table->s->mysql_version ||
|
||||
(table->s->frm_version < FRM_VER_TRUE_VARCHAR && varchar))
|
||||
DBUG_RETURN(ALTER_TABLE_DATA_CHANGED);
|
||||
|
||||
|
|
Loading…
Reference in a new issue