Spróbuj wprowadzić ograniczenie dotyczące dodawania nowego rekordu do tabeli. Zgłoś błąd, gdy ma zostać dodany nowy rekord.
DELIMITER $$
CREATE TRIGGER trigger1
BEFORE INSERT
ON table1
FOR EACH ROW
BEGIN
SELECT COUNT(*) INTO @cnt FROM table1;
IF @cnt >= 25 THEN
CALL sth(); -- raise an error
END IF;
END
$$
DELIMITER ;
Pamiętaj, że operacja COUNT może być powolna na dużych tabelach InnoDb.
W MySQL 5.5 możesz użyć SIGNAL // RESIGNAL oświadczenie, aby zgłosić błąd.