mirror of
https://github.com/MariaDB/server.git
synced 2025-07-27 18:02:13 +03:00
MDEV-5406 add index to an innodb table with a uniqueness violation crashes mysqld
After table->file->add_index() in mysql_alter_table() the table in the engine has the intermediate temporary structure, it's neither the original nor the final table structure (it'll be final after successful table->file->drop_index() call). So, when add_index() fails with a unique key violation, we cannot simply get the failed key number and easily map it to the key name and key structure via table->key_info[key_no]. For now we'll create this "intermediate temporary structure", emulating InnoDB internal rules. This bug and the fix will go away in 10.0 that uses completely different online alter table code. mysql-test/t/alter_table_trans.test: mdev:5406
This commit is contained in:
@ -4,3 +4,15 @@ ALTER TABLE t1 RENAME TO t2, DISABLE KEYS;
|
||||
Warnings:
|
||||
Note 1031 Table storage engine for 't1' doesn't have this option
|
||||
DROP TABLE t2;
|
||||
CREATE TABLE t1 (
|
||||
col4 text NOT NULL,
|
||||
col2 int(11) NOT NULL DEFAULT '0',
|
||||
col3 int(11) DEFAULT NULL,
|
||||
extra int(11) DEFAULT NULL,
|
||||
KEY idx (col4(10))
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
|
||||
insert t1 values (repeat('1', 8193),3,1,1);
|
||||
insert t1 values (repeat('3', 8193),3,1,1);
|
||||
ALTER TABLE t1 ADD PRIMARY KEY (col4(10)) , ADD UNIQUE KEY uidx (col3);
|
||||
ERROR 23000: Duplicate entry '1' for key 'uidx'
|
||||
DROP TABLE t1;
|
||||
|
Reference in New Issue
Block a user