mirror of
https://github.com/MariaDB/server.git
synced 2025-01-16 20:12:31 +01:00
e709eb9bf7
# Conflicts: # mysql-test/suite/galera/r/MW-388.result # mysql-test/suite/galera/t/MW-388.test # mysql-test/suite/innodb/r/truncate_inject.result # mysql-test/suite/innodb/t/truncate_inject.test # mysql-test/suite/rpl/r/rpl_stop_slave.result # mysql-test/suite/rpl/t/rpl_stop_slave.test # sql/sp_head.cc # sql/sp_head.h # sql/sql_lex.cc # sql/sql_yacc.yy # storage/xtradb/buf/buf0dblwr.cc
43 lines
1.3 KiB
Text
43 lines
1.3 KiB
Text
#
|
|
# BUG#40827 - Killing insert-select to MyISAM can cause table corruption
|
|
#
|
|
CONNECT insertConn, localhost, root,,;
|
|
CREATE TABLE `t1` (
|
|
`id` BIGINT(20) ,
|
|
`id1` BIGINT(20) AUTO_INCREMENT,
|
|
KEY(id1), KEY(id)
|
|
) ENGINE=MyISAM;
|
|
CREATE TABLE `t2` (
|
|
`id` BIGINT(20) ,
|
|
`id1` BIGINT(20) AUTO_INCREMENT,
|
|
KEY (id1), KEY(id)
|
|
) ENGINE=MyISAM;
|
|
INSERT INTO t2 (id) VALUES (123);
|
|
connection insertConn;
|
|
SET SESSION debug_dbug='+d,wait_in_enable_indexes';
|
|
# Send insert data
|
|
INSERT INTO t1(id) SELECT id FROM t2;
|
|
connection default;
|
|
# Wait for insert data to reach the debug point
|
|
SELECT ID FROM INFORMATION_SCHEMA.PROCESSLIST
|
|
WHERE STATE = 'wait_in_enable_indexes' AND
|
|
INFO = "INSERT INTO t1(id) SELECT id FROM t2"
|
|
INTO @thread_id;
|
|
KILL QUERY @thread_id;
|
|
CHECK TABLE t1;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 check status OK
|
|
DROP TABLE t1,t2;
|
|
disconnect insertConn;
|
|
call mtr.add_suppression("Index for table '.*test.t1\\.MYI' is corrupt; try to repair it");
|
|
create table t1 (a int, index(a));
|
|
lock tables t1 write;
|
|
insert t1 values (1),(2),(1);
|
|
set @old_dbug=@@debug_dbug;
|
|
SET debug_dbug='+d,mi_lock_database_failure';
|
|
unlock tables;
|
|
Warnings:
|
|
Error 126 Index for table './test/t1.MYI' is corrupt; try to repair it
|
|
Error 1030 Got error 22 "Invalid argument" from storage engine MyISAM
|
|
SET debug_dbug=@old_dbug;
|
|
drop table t1;
|