1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
|
--echo #
--echo # MDEV-36959 Deadlock does not rollback transaction fully
--echo #
--source include/have_log_bin.inc
--source include/have_innodb.inc
--source include/count_sessions.inc
CREATE TABLE t1(col1 INT PRIMARY KEY, col2 INT) ENGINE=InnoDB;
INSERT INTO t1 VALUES (1, 1), (2, 2);
SELECT * FROM t1;
--connect (con1,localhost,root,,)
START TRANSACTION;
--echo # Trx-1: Lock 1st record
UPDATE t1 SET col2=10 where col1=1;
--connection default
START TRANSACTION;
--echo # Trx-2: Lock 2nd record
UPDATE t1 SET col2=100 where col1=2;
--connection con1
--echo # Trx-1: Try locking 1st record : Wait
--send UPDATE t1 SET col2=10 where col1=2
--connection default
--echo # Wait for Trx-1 to get into lock wait stage
let $wait_condition=
SELECT COUNT(*) >= 2 FROM INFORMATION_SCHEMA.INNODB_LOCKS
WHERE lock_table like "%t1%";
--source include/wait_condition.inc
--echo # Trx-2: Try locking 2nd record : Deadlock
--error ER_LOCK_DEADLOCK
UPDATE t1 SET col2=100 where col1=1;
--connection con1
--reap
ROLLBACK;
--connection default
SELECT @@in_transaction;
UPDATE t1 SET col2=10 where col1=1;
UPDATE t1 SET col2=100 where col1=2;
SELECT @@in_transaction;
ROLLBACK;
SELECT * FROM t1;
DROP TABLE t1;
--echo #
--echo # MDEV-37141 DML committed within XA transaction block after deadlock error and implicit rollback
--echo #
CREATE TABLE t1(col1 INT PRIMARY KEY, col2 INT) ENGINE=InnoDB;
INSERT INTO t1 VALUES (1, 1), (2, 2);
SELECT * FROM t1;
--connection con1
XA BEGIN 'x1';
--echo # XA Trx-1: Lock 1st record
UPDATE t1 SET col2=10 where col1=1;
--connection default
XA BEGIN 'x2';
--echo # XA Trx-2: Lock 2nd record
UPDATE t1 SET col2=100 where col1=2;
--connection con1
--echo # XA Trx-1: Try locking 1st record : Wait
--send UPDATE t1 SET col2=10 where col1=2
--connection default
--echo # Wait for XA Trx-1 to get into lock wait stage
let $wait_condition=
SELECT COUNT(*) >= 2 FROM INFORMATION_SCHEMA.INNODB_LOCKS
WHERE lock_table like "%t1%";
--source include/wait_condition.inc
--echo # XA Trx-2: Try locking 2nd record : Deadlock
--error ER_LOCK_DEADLOCK
UPDATE t1 SET col2=100 where col1=1;
--error ER_XAER_RMFAIL
INSERT INTO t1 VALUES (3, 3), (4, 4);
--error ER_XAER_RMFAIL
XA END 'x2';
XA ROLLBACK 'x2';
--connection con1
--reap
XA END 'x1';
XA ROLLBACK 'x1';
--connection default
SELECT * FROM t1;
DROP TABLE t1;
--disconnect con1
--source include/wait_until_count_sessions.inc
|