mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-26 16:38:11 +01:00 
			
		
		
		
	 d270525dfd
			
		
	
	
	d270525dfd
	
	
	
		
			
			- In ha_innobase::prepare_inplace_alter_table(), InnoDB should check whether the table is empty. If the table is empty then server should avoid downgrading the MDL after prepare phase. It is more like instant alter, does change only in dicationary and metadata. - Changed few debug test case to make non-empty DDL table
		
			
				
	
	
		
			28 lines
		
	
	
	
		
			729 B
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
	
		
			729 B
		
	
	
	
		
			Text
		
	
	
	
	
	
| #
 | |
| # MDEV-23244 ALTER TABLE…ADD PRIMARY KEY fails to flag
 | |
| # duplicate key error from concurrent DML
 | |
| #
 | |
| CREATE TABLE t0 (pk INT PRIMARY KEY) ENGINE=InnoDB;
 | |
| CREATE TABLE t1 (c CHAR(2) NOT NULL) ENGINE=InnoDB;
 | |
| INSERT INTO  t1 VALUES('cd');
 | |
| connect  con1,localhost,root,,;
 | |
| BEGIN;
 | |
| INSERT INTO t0 VALUES(1);
 | |
| connection default;
 | |
| SET DEBUG_SYNC='row_log_table_apply1_before SIGNAL dml WAIT_FOR dml_done';
 | |
| ALTER TABLE t1 ADD PRIMARY KEY(c(1));
 | |
| connection con1;
 | |
| SET DEBUG_SYNC='now WAIT_FOR dml';
 | |
| INSERT INTO t1 VALUES ('ab'),('ac');
 | |
| COMMIT;
 | |
| SET DEBUG_SYNC='now SIGNAL dml_done';
 | |
| disconnect con1;
 | |
| connection default;
 | |
| ERROR 23000: Duplicate entry 'a' for key 'PRIMARY'
 | |
| SET DEBUG_SYNC='RESET';
 | |
| SELECT * FROM t1;
 | |
| c
 | |
| cd
 | |
| ab
 | |
| ac
 | |
| DROP TABLE t0,t1;
 |