Mysql
 sql >> Database >  >> RDS >> Mysql

MySQL VARCHAR come Tipo di dati con lunghezze di carattere MIN e MAX

Puoi aggiungere un trigger per generare un'eccezione quando i valori sono al di fuori dell'intervallo, ad esempio

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 ;;

Sebbene SIGNAL non sia disponibile, sarebbe sufficiente chiamare una procedura memorizzata non definita (in questo caso col_length_outside_range_error ). In caso contrario, penso che l'applicazione che utilizza il database dovrà eseguire i controlli.