mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-26 01:18:31 +02:00 
			
		
		
		
	 4e1e9ea6f3
			
		
	
	
	4e1e9ea6f3
	
	
	
		
			
			From the very beginning, the default InnoDB transaction isolation level
REPEATABLE READ does not correspond to any well formed definition.
The main issue is the lack of write/write conflict detection.
To fix that and to make REPEATABLE READ correspond to Snapshot Isolation,
b8a6719889 introduced the Boolean
session variable innodb_snapshot_isolation. It was disabled by default
in order not to break any user applications.
In a new major version of MariaDB Server, we had better enable this
parameter by default.
		
	
			
		
			
				
	
	
		
			34 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			34 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| CREATE TABLE t (a int PRIMARY KEY, b int) engine = InnoDB STATS_PERSISTENT=0;
 | |
| CREATE TABLE t2 (a int PRIMARY KEY) engine = InnoDB STATS_PERSISTENT=0;
 | |
| INSERT INTO t VALUES (10, 10), (20, 20), (30, 30);
 | |
| INSERT INTO t2 VALUES (10), (20), (30);
 | |
| BEGIN;
 | |
| UPDATE t2 SET a = a + 100;
 | |
| SELECT * FROM t WHERE a = 20 FOR UPDATE;
 | |
| a	b
 | |
| 20	20
 | |
| connect con_2,localhost,root,,;
 | |
| SET innodb_snapshot_isolation=OFF;
 | |
| SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
 | |
| SET DEBUG_SYNC = 'lock_trx_handle_wait_enter SIGNAL upd_locked WAIT_FOR upd_cont';
 | |
| SET DEBUG_SYNC = 'trx_t_release_locks_enter SIGNAL sel_cont WAIT_FOR upd_cont_2';
 | |
| BEGIN;
 | |
| UPDATE t SET b = 100;
 | |
| connection default;
 | |
| SET DEBUG_SYNC="now WAIT_FOR upd_locked";
 | |
| SET DEBUG_SYNC="deadlock_report_before_lock_releasing SIGNAL upd_cont WAIT_FOR sel_cont";
 | |
| SET DEBUG_SYNC="lock_wait_before_suspend SIGNAL sel_before_suspend";
 | |
| SELECT * FROM t WHERE a = 10 FOR UPDATE;;
 | |
| connect con_3,localhost,root,,;
 | |
| SET DEBUG_SYNC="now WAIT_FOR sel_before_suspend";
 | |
| SET DEBUG_SYNC="now SIGNAL upd_cont_2";
 | |
| disconnect con_3;
 | |
| connection con_2;
 | |
| ERROR 40001: Deadlock found when trying to get lock; try restarting transaction
 | |
| disconnect con_2;
 | |
| connection default;
 | |
| a	b
 | |
| 10	10
 | |
| SET DEBUG_SYNC = 'RESET';
 | |
| DROP TABLE t;
 | |
| DROP TABLE t2;
 |