Możesz dodać wyzwalacz, aby zgłosić wyjątek, gdy wartości są poza zakresem, np.
DELIMITER $$
CREATE TRIGGER `insert_table_var` BEFORE INSERT ON `table`
FOR EACH ROW
BEGIN
DECLARE str_len INT DEFAULT 0;
DECLARE max_len INT DEFAULT 10;
DECLARE min_len INT DEFAULT 6;
SET str_len = LENGTH(NEW.col);
IF str_len > max_len OR str_len < min_len
THEN
CALL col_length_outside_range_error();
END IF;
END $$
DELIMITER ;;
Chociaż SIGNAL nie jest dostępny, wystarczy wywołanie niezdefiniowanej procedury składowanej (w tym przypadku col_length_outside_range_error
). W przeciwnym razie uważam, że aplikacja korzystająca z bazy danych będzie musiała przeprowadzić kontrolę.