mirror of
https://github.com/MariaDB/server.git
synced 2025-10-24 00:27:49 +02:00

slave_applier_reset_xa_trans() should clear the THD::pseudo_thread_id when called to reset XA transaction state completely. Clearing when pseudo_thread_id models the binlog applier that handles BASE64-encoded events which possibly contain the pseudo_thread_id, allowing us to restore the pre-event's state of the connection's respective session var.
17 lines
458 B
Text
17 lines
458 B
Text
SET pseudo_slave_mode=1;
|
|
CREATE TABLE t1 (c INT) ENGINE=InnoDB;
|
|
CREATE TABLE t2 (c INT) ENGINE=MEMORY;
|
|
XA START 'a';
|
|
INSERT INTO t1 VALUES (0);
|
|
CREATE TEMPORARY TABLE t1t (c INT) ENGINE=InnoDB;
|
|
INSERT INTO t1t VALUES (0);
|
|
XA END 'a';
|
|
XA PREPARE 'a';
|
|
OPTIMIZE TABLE t1t;
|
|
Table Op Msg_type Msg_text
|
|
test.t1t optimize Error Table 'test.t1t' doesn't exist
|
|
test.t1t optimize status Operation failed
|
|
LOCK TABLE t2 READ;
|
|
XA COMMIT 'a';
|
|
# restart
|
|
DROP TABLE t1, t2;
|