mirror of
https://github.com/MariaDB/server.git
synced 2025-02-07 06:12:18 +01:00
![Junqi Xie](/assets/img/avatar_default.png)
In MariaDB, we have a confusing problem where: * The transaction_isolation option can be set in a configuration file, but it cannot be set dynamically. * The tx_isolation system variable can be set dynamically, but it cannot be set in a configuration file. Therefore, we have two different names for the same thing in different contexts. This is needlessly confusing, and it complicates the documentation. The same thing applys for transaction_read_only. MySQL 5.7 solved this problem by making them into system variables. https://dev.mysql.com/doc/relnotes/mysql/5.7/en/news-5-7-20.html This commit takes a similar approach by adding new system variables and marking the original ones as deprecated. This commit also resolves some legacy problems related to SET STATEMENT and transaction_isolation.
47 lines
945 B
Text
47 lines
945 B
Text
--source include/have_innodb.inc
|
|
|
|
# Bug #49164 READ-COMMITTED reports "matched: 0" on compound PK
|
|
# a duplicate of
|
|
# Bug #52663 Lost update incrementing column value under READ COMMITTED
|
|
|
|
connect (con1,localhost,root,,);
|
|
connect (con2,localhost,root,,);
|
|
|
|
connection con1;
|
|
SET transaction_isolation = 'READ-COMMITTED';
|
|
|
|
CREATE TABLE bug49164 (a INT, b BIGINT, c TINYINT, PRIMARY KEY (a, b))
|
|
ENGINE=InnoDB;
|
|
|
|
insert into bug49164 values (1,1,1), (2,2,2), (3,3,3);
|
|
|
|
begin;
|
|
update bug49164 set c=7;
|
|
select * from bug49164;
|
|
rollback;
|
|
select * from bug49164;
|
|
begin;
|
|
update bug49164 set c=7;
|
|
|
|
connection con2;
|
|
|
|
SET transaction_isolation = 'READ-COMMITTED';
|
|
begin;
|
|
select * from bug49164;
|
|
commit;
|
|
begin;
|
|
--send
|
|
update bug49164 set c=6 where a=1 and b=1;
|
|
|
|
connection con1;
|
|
rollback;
|
|
select * from bug49164;
|
|
connection con2;
|
|
reap;
|
|
commit;
|
|
connection con1;
|
|
select * from bug49164;
|
|
connection default;
|
|
disconnect con1;
|
|
disconnect con2;
|
|
drop table bug49164;
|