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.