mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	Problem: SELECTs prohibited for a transactional SE in autocommit mode if read_only is set. Fix: allow them. mysql-test/r/read_only_innodb.result: Fix for bug #35732: read-only blocks SELECT statements in InnoDB - test result. mysql-test/t/read_only_innodb.test: Fix for bug #35732: read-only blocks SELECT statements in InnoDB - test case. sql/handler.cc: Fix for bug #35732: read-only blocks SELECT statements in InnoDB - in autocommit mode thd->transaction.all list is empty thus is_real_trans set to TRUE for any SELECTs, so using it in the "read_only" check is insufficient. ha_check_and_coalesce_trx_read_only() changed to return number of engines with read-write changes. This value is used in the "read-only" check and checks for GLOBAL READ LOCK. sql/lock.cc: Fix for bug #35732: read-only blocks SELECT statements in InnoDB - added assert(protect_against_global_read_lock) before decreasing, in order to catch (uint) 0 - 1 situation due to wrong wait_if_global_read_lock()/start_waiting_global_read_lock() call sequence.
		
			
				
	
	
		
			86 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| # should work with embedded server after mysqltest is fixed
 | |
| -- source include/not_embedded.inc
 | |
| -- source include/have_innodb.inc
 | |
| 
 | |
| #
 | |
| # BUG#11733: COMMITs should not happen if read-only is set
 | |
| #
 | |
| 
 | |
| --disable_warnings
 | |
| DROP TABLE IF EXISTS table_11733 ;
 | |
| --enable_warnings
 | |
| 
 | |
| # READ_ONLY does nothing to SUPER users
 | |
| # so we use a non-SUPER one:
 | |
| 
 | |
| grant CREATE, SELECT, DROP on *.* to test@localhost;
 | |
| 
 | |
| connect (con1,localhost,test,,test);
 | |
| 
 | |
| connection default;
 | |
| set global read_only=0;
 | |
| 
 | |
| # Any transactional engine will do
 | |
| create table table_11733 (a int) engine=InnoDb;
 | |
| 
 | |
| connection con1;
 | |
| BEGIN;
 | |
| insert into table_11733 values(11733);
 | |
| 
 | |
| connection default;
 | |
| set global read_only=1;
 | |
| 
 | |
| connection con1;
 | |
| select @@global.read_only;
 | |
| select * from table_11733 ;
 | |
| -- error ER_OPTION_PREVENTS_STATEMENT
 | |
| COMMIT;
 | |
| 
 | |
| connection default;
 | |
| set global read_only=0;
 | |
| drop table table_11733 ;
 | |
| drop user test@localhost;
 | |
| 
 | |
| disconnect con1;
 | |
| 
 | |
| #
 | |
| # Bug #35732: read-only blocks SELECT statements in InnoDB
 | |
| #
 | |
| # Test 1: read only mode
 | |
| GRANT CREATE, SELECT, DROP ON *.* TO test@localhost;
 | |
| connect(con1, localhost, test, , test);
 | |
| 
 | |
| connection default;
 | |
| CREATE TABLE t1(a INT) ENGINE=INNODB;
 | |
| INSERT INTO t1 VALUES (0), (1);
 | |
| SET GLOBAL read_only=1;
 | |
| 
 | |
| connection con1;
 | |
| SELECT * FROM t1;
 | |
| BEGIN;
 | |
| SELECT * FROM t1;
 | |
| COMMIT;
 | |
| 
 | |
| connection default;
 | |
| SET GLOBAL read_only=0;
 | |
| 
 | |
| #
 | |
| # Test 2: global read lock
 | |
| #
 | |
| FLUSH TABLES WITH READ LOCK;
 | |
| 
 | |
| connection con1;
 | |
| SELECT * FROM t1;
 | |
| BEGIN;
 | |
| SELECT * FROM t1;
 | |
| COMMIT;
 | |
| 
 | |
| connection default;
 | |
| UNLOCK TABLES;
 | |
| DROP TABLE t1;
 | |
| DROP USER test@localhost;
 | |
| 
 | |
| disconnect con1;
 | |
| 
 | |
| --echo echo End of 5.1 tests 
 |