値が範囲外の場合に例外をスローするトリガーを追加できます。例:
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 ;;
SIGNALは使用できませんが、未定義のストアドプロシージャを呼び出すだけで十分です(この場合はcol_length_outside_range_error
)。そうでなければ、データベースを使用するアプリケーションがチェックを行う必要があると思います。