mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-26 08:28:13 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			49 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| #
 | |
| # ALTER TABLE ... ADD PRIMARY KEY under Rolling Schema Upgrade
 | |
| #
 | |
| 
 | |
| --source include/big_test.inc
 | |
| --source include/galera_cluster.inc
 | |
| --source include/have_innodb.inc
 | |
| 
 | |
| --connection node_1
 | |
| CREATE TABLE ten (f1 INTEGER);
 | |
| INSERT INTO ten VALUES (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
 | |
| 
 | |
| CREATE TABLE t1 (f1 INTEGER) Engine=InnoDB;
 | |
| 
 | |
| # Insert some values before the ALTER
 | |
| INSERT INTO t1 (f1) SELECT 000000 + (10000 * a1.f1) + (1000 * a2.f1) + (100 * a3.f1) + (10 * a4.f1) + a5.f1 FROM ten AS a1, ten AS a2, ten AS a3, ten AS a4, ten AS a5;
 | |
| 
 | |
| # Insert more values while the ALTER is running
 | |
| --send INSERT INTO t1 (f1) SELECT 100000 + (10000 * a1.f1) + (1000 * a2.f1) + (100 * a3.f1) + (10 * a4.f1) + a5.f1 FROM ten AS a1, ten AS a2, ten AS a3, ten AS a4, ten AS a5;
 | |
| 
 | |
| --connection node_2
 | |
| SET SESSION wsrep_OSU_method = "RSU";
 | |
| ALTER TABLE t1 ADD PRIMARY KEY (f1);
 | |
| SET SESSION wsrep_OSU_method = "TOI";
 | |
| 
 | |
| # Insert values after the ALTER
 | |
| INSERT INTO t1 (f1) SELECT 200000 + (10000 * a1.f1) + (1000 * a2.f1) + (100 * a3.f1) + (10 * a4.f1) + a5.f1 FROM ten AS a1, ten AS a2, ten AS a3, ten AS a4, ten AS a5;
 | |
| 
 | |
| --let $wait_condition = SELECT COUNT(*) = 300000 FROM t1;
 | |
| --source include/wait_condition.inc
 | |
| 
 | |
| SELECT COUNT(*) AS EXPECT_300000 FROM t1;
 | |
| SELECT MAX(f1) AS EXPECT_299999 FROM t1;
 | |
| 
 | |
| --connection node_1
 | |
| --reap
 | |
| 
 | |
| --let $wait_condition = SELECT COUNT(*) = 300000 FROM t1;
 | |
| --source include/wait_condition.inc
 | |
| 
 | |
| SELECT COUNT(*) AS EXPECT_300000 FROM t1;
 | |
| SELECT MAX(f1) AS EXPECT_299999 FROM t1;
 | |
| 
 | |
| SET SESSION wsrep_OSU_method = "RSU";
 | |
| ALTER TABLE t1 ADD PRIMARY KEY (f1);
 | |
| SET SESSION wsrep_OSU_method = "TOI";
 | |
| 
 | |
| DROP TABLE t1;
 | |
| DROP TABLE ten;
 | 
