2016-03-25 20:51:22 +04:00
|
|
|
connect con1,localhost,root,,;
|
|
|
|
connect con2,localhost,root,,;
|
2003-01-06 01:48:59 +02:00
|
|
|
drop table if exists t1,t2;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con1;
|
2006-08-16 14:58:49 +02:00
|
|
|
create table t1 (id integer, x integer) engine = InnoDB;
|
2002-11-24 21:39:22 +02:00
|
|
|
insert into t1 values(0, 0);
|
|
|
|
set autocommit=0;
|
|
|
|
SELECT * from t1 where id = 0 FOR UPDATE;
|
|
|
|
id x
|
|
|
|
0 0
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con2;
|
2002-11-24 21:39:22 +02:00
|
|
|
set autocommit=0;
|
|
|
|
update t1 set x=2 where id = 0;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con1;
|
2002-11-24 21:39:22 +02:00
|
|
|
update t1 set x=1 where id = 0;
|
|
|
|
select * from t1;
|
|
|
|
id x
|
|
|
|
0 1
|
|
|
|
commit;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con2;
|
2002-11-24 21:39:22 +02:00
|
|
|
commit;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con1;
|
2002-11-24 21:39:22 +02:00
|
|
|
select * from t1;
|
|
|
|
id x
|
|
|
|
0 2
|
|
|
|
commit;
|
|
|
|
drop table t1;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con1;
|
2006-08-16 14:58:49 +02:00
|
|
|
create table t1 (id integer, x integer) engine = InnoDB;
|
|
|
|
create table t2 (b integer, a integer) engine = InnoDB;
|
2002-11-25 18:34:24 +02:00
|
|
|
insert into t1 values(0, 0), (300, 300);
|
|
|
|
insert into t2 values(0, 10), (1, 20), (2, 30);
|
|
|
|
commit;
|
|
|
|
set autocommit=0;
|
|
|
|
select * from t2;
|
|
|
|
b a
|
|
|
|
0 10
|
|
|
|
1 20
|
|
|
|
2 30
|
|
|
|
update t2 set a=100 where b=(SELECT x from t1 where id = b FOR UPDATE);
|
|
|
|
select * from t2;
|
|
|
|
b a
|
|
|
|
0 100
|
|
|
|
1 20
|
|
|
|
2 30
|
|
|
|
select * from t1;
|
|
|
|
id x
|
|
|
|
0 0
|
|
|
|
300 300
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con2;
|
2002-11-25 18:34:24 +02:00
|
|
|
set autocommit=0;
|
|
|
|
update t1 set x=2 where id = 0;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con1;
|
2002-11-25 18:34:24 +02:00
|
|
|
update t1 set x=1 where id = 0;
|
|
|
|
select * from t1;
|
|
|
|
id x
|
|
|
|
0 1
|
|
|
|
300 300
|
|
|
|
commit;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con2;
|
2002-11-25 18:34:24 +02:00
|
|
|
commit;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con1;
|
2002-11-25 18:34:24 +02:00
|
|
|
select * from t1;
|
|
|
|
id x
|
|
|
|
0 2
|
|
|
|
300 300
|
|
|
|
commit;
|
|
|
|
drop table t1, t2;
|
2006-08-16 14:58:49 +02:00
|
|
|
create table t1 (id integer, x integer) engine = InnoDB;
|
|
|
|
create table t2 (b integer, a integer) engine = InnoDB;
|
2002-11-25 18:34:24 +02:00
|
|
|
insert into t1 values(0, 0), (300, 300);
|
|
|
|
insert into t2 values(0, 0), (1, 20), (2, 30);
|
|
|
|
commit;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con1;
|
2018-05-22 19:08:39 +02:00
|
|
|
select a,b from t2 UNION (SELECT id, x from t1 FOR UPDATE);
|
2002-11-25 18:34:24 +02:00
|
|
|
a b
|
|
|
|
0 0
|
|
|
|
20 1
|
|
|
|
30 2
|
|
|
|
300 300
|
|
|
|
select * from t2;
|
|
|
|
b a
|
|
|
|
0 0
|
|
|
|
1 20
|
|
|
|
2 30
|
|
|
|
select * from t1;
|
|
|
|
id x
|
|
|
|
0 0
|
|
|
|
300 300
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con2;
|
2002-11-25 18:34:24 +02:00
|
|
|
update t2 set a=2 where b = 0;
|
|
|
|
update t1 set x=2 where id = 0;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con1;
|
2002-11-25 18:34:24 +02:00
|
|
|
update t1 set x=1 where id = 0;
|
|
|
|
select * from t1;
|
|
|
|
id x
|
|
|
|
0 1
|
|
|
|
300 300
|
|
|
|
commit;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con2;
|
2002-11-25 18:34:24 +02:00
|
|
|
commit;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection con1;
|
2002-11-25 18:34:24 +02:00
|
|
|
select * from t1;
|
|
|
|
id x
|
|
|
|
0 2
|
|
|
|
300 300
|
|
|
|
commit;
|
2016-03-25 20:51:22 +04:00
|
|
|
connection default;
|
|
|
|
disconnect con1;
|
|
|
|
disconnect con2;
|
2002-11-25 18:34:24 +02:00
|
|
|
drop table t1, t2;
|
Bug#25164 create table `a` as select * from `A` hangs
The problem from a user's perspective: user creates table A, and then tries
to CREATE TABLE a SELECT from A - and this causes a deadlock error, a hang,
or fails with a debug assert, but only if the storage engine is InnoDB.
The origin of the problem: InnoDB uses case-insensitive collation
(system_charset_info) when looking up the internal table share, thus returning
the same share for 'a' and 'A'.
Cause of the user-visible behavior: since the same share is returned to SQL
locking subsystem, it assumes that the same table is first locked (within the
same session) for WRITE, and then for READ, and returns a deadlock error.
However, the code is wrong in not properly cleaning up upon an error, leaving
external locks in place, which leads to assertion failures and hangs.
Fix that has been implemented: the SQL layer should properly propagate the
deadlock error, cleaning up and freeing all resources.
Further work towards a more complete solution: InnoDB should not use case
insensitive collation for table share hash if table names on disk honor the case.
mysql-test/r/innodb-deadlock.result:
Bug#25164 test case result
mysql-test/t/innodb-deadlock.test:
Bug#25164 test case. The CREATE TABLE may fail depending on the character set
of the system and filesystem, but it should never hang.
sql/lock.cc:
Unlock the storage engine "external" table level locks, if the MySQL thr_lock
locking subsystem detects a deadlock error.
2007-08-27 10:13:54 -03:00
|
|
|
End of 4.1 tests
|
2020-01-13 21:07:04 +02:00
|
|
|
set default_storage_engine=innodb;
|
Bug#25164 create table `a` as select * from `A` hangs
The problem from a user's perspective: user creates table A, and then tries
to CREATE TABLE a SELECT from A - and this causes a deadlock error, a hang,
or fails with a debug assert, but only if the storage engine is InnoDB.
The origin of the problem: InnoDB uses case-insensitive collation
(system_charset_info) when looking up the internal table share, thus returning
the same share for 'a' and 'A'.
Cause of the user-visible behavior: since the same share is returned to SQL
locking subsystem, it assumes that the same table is first locked (within the
same session) for WRITE, and then for READ, and returns a deadlock error.
However, the code is wrong in not properly cleaning up upon an error, leaving
external locks in place, which leads to assertion failures and hangs.
Fix that has been implemented: the SQL layer should properly propagate the
deadlock error, cleaning up and freeing all resources.
Further work towards a more complete solution: InnoDB should not use case
insensitive collation for table share hash if table names on disk honor the case.
mysql-test/r/innodb-deadlock.result:
Bug#25164 test case result
mysql-test/t/innodb-deadlock.test:
Bug#25164 test case. The CREATE TABLE may fail depending on the character set
of the system and filesystem, but it should never hang.
sql/lock.cc:
Unlock the storage engine "external" table level locks, if the MySQL thr_lock
locking subsystem detects a deadlock error.
2007-08-27 10:13:54 -03:00
|
|
|
drop table if exists a;
|
|
|
|
drop table if exists A;
|
|
|
|
create table A (c int);
|
|
|
|
insert into A (c) values (0);
|
|
|
|
create table a as select * from A;
|
|
|
|
drop table A;
|
|
|
|
drop table if exists a;
|
2020-01-13 21:07:04 +02:00
|
|
|
set default_storage_engine=default;
|
Bug#25164 create table `a` as select * from `A` hangs
The problem from a user's perspective: user creates table A, and then tries
to CREATE TABLE a SELECT from A - and this causes a deadlock error, a hang,
or fails with a debug assert, but only if the storage engine is InnoDB.
The origin of the problem: InnoDB uses case-insensitive collation
(system_charset_info) when looking up the internal table share, thus returning
the same share for 'a' and 'A'.
Cause of the user-visible behavior: since the same share is returned to SQL
locking subsystem, it assumes that the same table is first locked (within the
same session) for WRITE, and then for READ, and returns a deadlock error.
However, the code is wrong in not properly cleaning up upon an error, leaving
external locks in place, which leads to assertion failures and hangs.
Fix that has been implemented: the SQL layer should properly propagate the
deadlock error, cleaning up and freeing all resources.
Further work towards a more complete solution: InnoDB should not use case
insensitive collation for table share hash if table names on disk honor the case.
mysql-test/r/innodb-deadlock.result:
Bug#25164 test case result
mysql-test/t/innodb-deadlock.test:
Bug#25164 test case. The CREATE TABLE may fail depending on the character set
of the system and filesystem, but it should never hang.
sql/lock.cc:
Unlock the storage engine "external" table level locks, if the MySQL thr_lock
locking subsystem detects a deadlock error.
2007-08-27 10:13:54 -03:00
|
|
|
End of 5.0 tests.
|