mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-30 04:26:45 +03:00 
			
		
		
		
	triggers". Applying ALTER/OPTIMIZE/REPAIR TABLE statements to transactional table or to table of any type on Windows caused disappearance of its triggers. Bug was introduced in 5.0.19 by my fix for bug #13525 "Rename table does not keep info of triggers" (see comment for sql_table.cc for more info). . mysql-test/r/trigger.result: Added test-case covering handling of triggers when one does ALTER TABLE which should move table to different database. mysql-test/t/trigger.test: Added test-case covering handling of triggers when one does ALTER TABLE which should move table to different database. sql/sql_table.cc: mysql_alter_table(): Removal of strdup() which is no longer necessary allows us to preserve nice assumption that "(new_db != db || new_table != table_name) indicates that table will be renamed. So now we really can use this condition to avoid updating trigger definitions when table is not renamed. Note that we can't use (alter_info->flags & ALTER_RENAME) condition instead since it can be also true when we do "ALTER TABLE t1 RENAME TO t1". sql/sql_trigger.cc: Table_triggers_list::change_table_name(): Mentioned assumption that subject table is not renamed to itself in method description. Added DBUG_ASSERT() to catch wrong usage of this method. mysql-test/r/trigger-trans.result: New BitKeeper file ``mysql-test/r/trigger-trans.result'' mysql-test/t/trigger-trans.test: New BitKeeper file ``mysql-test/t/trigger-trans.test''
		
			
				
	
	
		
			53 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| # Tests which involve triggers and transactions
 | |
| # (or just InnoDB storage engine)
 | |
| --source include/have_innodb.inc
 | |
| 
 | |
| --disable_warnings
 | |
| drop table if exists t1;
 | |
| --enable_warnings
 | |
| 
 | |
| # Test for bug #18153 "OPTIMIZE/ALTER on transactional tables corrupt
 | |
| #                      triggers/triggers are lost".
 | |
| 
 | |
| create table t1 (a varchar(16), b int) engine=innodb;
 | |
| delimiter |;
 | |
| create trigger t1_bi before insert on t1 for each row
 | |
| begin
 | |
|  set new.a := upper(new.a);
 | |
|  set new.b := new.b + 3;
 | |
| end|
 | |
| delimiter ;|
 | |
| select trigger_schema, trigger_name, event_object_schema,
 | |
|        event_object_table, action_statement from information_schema.triggers
 | |
|        where event_object_schema = 'test' and event_object_table = 't1';
 | |
| insert into t1 values ('The Lion', 10);
 | |
| select * from t1;
 | |
| optimize table t1;
 | |
| select trigger_schema, trigger_name, event_object_schema,
 | |
|        event_object_table, action_statement from information_schema.triggers
 | |
|        where event_object_schema = 'test' and event_object_table = 't1';
 | |
| insert into t1 values ('The Unicorn', 20);
 | |
| select * from t1;
 | |
| alter table t1 add column c int default 0;
 | |
| select trigger_schema, trigger_name, event_object_schema,
 | |
|        event_object_table, action_statement from information_schema.triggers
 | |
|        where event_object_schema = 'test' and event_object_table = 't1';
 | |
| insert into t1 values ('Alice', 30, 1);
 | |
| select * from t1;
 | |
| # Special tricky cases allowed by ALTER TABLE ... RENAME
 | |
| alter table t1 rename to t1;
 | |
| select trigger_schema, trigger_name, event_object_schema,
 | |
|        event_object_table, action_statement from information_schema.triggers
 | |
|        where event_object_schema = 'test' and event_object_table = 't1';
 | |
| insert into t1 values ('The Crown', 40, 1);
 | |
| select * from t1;
 | |
| alter table t1 rename to t1, add column d int default 0;
 | |
| select trigger_schema, trigger_name, event_object_schema,
 | |
|        event_object_table, action_statement from information_schema.triggers
 | |
|        where event_object_schema = 'test' and event_object_table = 't1';
 | |
| insert into t1 values ('The Pie', 50, 1, 1);
 | |
| select * from t1;
 | |
| drop table t1;
 | |
| 
 | |
| # End of 5.0 tests
 |