mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-24 07:13:33 +03:00 
			
		
		
		
	When setting AUTOCOMMIT=1 after starting a transaction, the binary log did not commit the outstanding transaction. The reason was that the binary log commit function saw the values of the new settings, deciding that there were nothing to commit. Fixed the problem by moving the implicit commit to before the thread option flags were changed, so that the binary log sees the old values of the flags instead of the values they will take after the statement. mysql-test/extra/binlog_tests/implicit.test: New test file to check implicit commits both inside and outside transactions. mysql-test/suite/binlog/t/binlog_implicit_commit.test: Test for implicit commit of SET AUTOCOMMIT and LOCK/UNLOCK TABLES. sql/set_var.cc: Adding code to commit pending transaction before changing option flags.
		
			
				
	
	
		
			29 lines
		
	
	
		
			601 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			29 lines
		
	
	
		
			601 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| # First part: outside a transaction
 | |
| RESET MASTER;
 | |
| eval $prepare;
 | |
| 
 | |
| INSERT INTO t1 VALUES (1);
 | |
| source include/show_binlog_events.inc;
 | |
| eval $statement;
 | |
| source include/show_binlog_events.inc;
 | |
| if (`select '$cleanup' != ''`) {
 | |
|   eval $cleanup;
 | |
| }
 | |
| 
 | |
| # Second part: inside a transaction
 | |
| RESET MASTER;
 | |
| eval $prepare;
 | |
| BEGIN;
 | |
| INSERT INTO t1 VALUES (2);
 | |
| source include/show_binlog_events.inc;
 | |
| eval $statement;
 | |
| source include/show_binlog_events.inc;
 | |
| INSERT INTO t1 VALUES (3);
 | |
| source include/show_binlog_events.inc;
 | |
| COMMIT;
 | |
| source include/show_binlog_events.inc;
 | |
| if (`select '$cleanup' != ''`) {
 | |
|   eval $cleanup;
 | |
| }
 | |
| 
 |