sql >> Databáze >  >> RDS >> Mysql

Je možné vynutit kontrolu dat v MySQL pomocí regulárního výrazu

Ano můžeš. MySQL podporuje regex (http://dev.mysql.com/doc /refman/5.6/en/regexp.html ) a pro ověření dat byste měli použít spouštěč, protože MySQL nepodporuje omezení CHECK (vždy se můžete alternativně přesunout na PostgreSQL:). NB! Uvědomte si, že i když MySQL má konstrukci omezení CHECK, bohužel MySQL (zatím 5.6) neověřuje data podle kontrolních omezení. Podle http://dev.mysql.com/doc /refman/5.6/en/create-table.html :"Klauzule CHECK je analyzována, ale ignorována všemi moduly úložiště."

Můžete přidat kontrolní omezení pro sloupec telefon :

CREATE TABLE data (
  phone varchar(100)
);

DELIMITER $$
CREATE TRIGGER trig_phone_check BEFORE INSERT ON data
FOR EACH ROW 
BEGIN 
IF (NEW.phone REGEXP '^(\\+?[0-9]{1,4}-)?[0-9]{3,10}$' ) = 0 THEN 
  SIGNAL SQLSTATE '12345'
     SET MESSAGE_TEXT = 'Wroooong!!!';
END IF; 
END$$
DELIMITER ;


INSERT INTO data VALUES ('+64-221221442'); -- should be OK
INSERT INTO data VALUES ('+64-22122 WRONG 1442'); -- will fail with the error: #1644 - Wroooong!!! 

Při ověřování dat byste se však neměli spoléhat pouze na MySQL (ve vašem případě datovou vrstvu). Data by měla být ověřena na všech úrovních vaší aplikace.



  1. Vraťte SETOF řádky z funkce PostgreSQL

  2. CTE získat všechny děti (potomky) rodiče

  3. Jak vytvořit databázi pro více tenantů se sdílenými strukturami tabulek?

  4. PGError:ERROR:povolení odepřeno pro vztah (při použití Heroku)