trigger, если коротко....  Поддержка триггеров в MySQL ver. > 5.0.2 
 trigger – поименованный объект БД, который ассоциирован с таблицей и активируемый при наступлении определенного события, события связанного с этой таблицей. 
 Например, нижеприведенный код создает таблицу и INSERT триггер. Триггер суммирует значения, вставляемые в один из столбцов таблицы. 
 
Code
 
 mysql> CREATE TABLE account (acct_num INT, amount DECIMAL(10,2)); 
 Query OK, 0 rows affected (0.03 sec) 
 mysql> CREATE TRIGGER ins_sum BEFORE INSERT ON account 
 -> FOR EACH ROW SET @sum = @sum + NEW.amount; 
 Query OK, 0 rows affected (0.06 sec) 
 
   
 
 Объявим переменную sum и присвоим ей значение 1. После этого при каждой вставке в таблицу account значение этой переменной будет увеличивать согласно вставляемой части. 
 Если значение переменной не инициализировано, то триггер работать не будет! 
 
 
 Синтаксис создания триггера 
 
Code
CREATE 
 [DEFINER = { имя_ пользователя | CURRENT_USER }] 
 TRIGGER имя_триггера время_триггера событие_срабатывания_триггера 
 ON имя_таблицы FOR EACH ROW выражение_выполняемое_при_срабатывании_триггера 
 Если с именем триггера и именем пользователя все понятно сразу, то о «времени триггера» и «событии» поговорим отдельно. 
  
 время_триггера  Определяет время свершения действия триггера. BEFORE означает, что триггер выполнится до завершения события срабатывания триггера, а AFTER означает, что после. Например, при вставке записей (см. пример выше) наш триггер срабатывал до фактической вставки записи и вычислял сумму. Такой вариант уместен при предварительном вычислении каких-то дополнительных полей в таблице или параллельной вставке в другую таблицу. 
 событие_срабатывания_триггера 
 Здесь все проще. Тут четко обозначается, при каком событии выполняется триггер. 
 INSERT: т.е. при операциях вставки или аналогичных ей выражениях (INSERT, LOAD DATA, и REPLACE) 
 UPDATE: когда сущность (строка) модифицирована 
 DELETE: когда запись удаляется (запросы, содержащие выражения DELETE и/или REPLACE) 
 типа того... лень было печатать - скопировал.. =)