| 63 | \\ Со употреба на тригер го форматирам мобилниот телефоснки број. Најпрво ја променив големината на полето бидејќи првично имавме назначено phoneNumber varchar(15), што е мала голема за телефонски број. При внес на телефоснки број во полето Vet Centers телефонскиот број автоматски се формитира со тоа што: доколку не започнува со +389 му се додава, доколку започнува со 0 се брише првата нула, и се бришат сите знаци освен знакот +. |
| 64 | {{{ |
| 65 | ALTER TABLE vet_centers |
| 66 | ALTER COLUMN phoneNumber TYPE varchar(50); |
| 67 | |
| 68 | CREATE OR REPLACE FUNCTION format_phone_number() |
| 69 | RETURNS TRIGGER AS $$ |
| 70 | BEGIN |
| 71 | -- Отстранување на сите не-нумерички знаци освен плусот на почетокот, ако постои |
| 72 | IF LEFT(NEW.phoneNumber, 1) = '+' THEN |
| 73 | NEW.phoneNumber := '+' || regexp_replace(SUBSTRING(NEW.phoneNumber FROM 2), '\D', '', 'g'); |
| 74 | ELSE |
| 75 | NEW.phoneNumber := regexp_replace(NEW.phoneNumber, '\D', '', 'g'); |
| 76 | END IF; |
| 77 | |
| 78 | -- Ако бројот веќе започнува со '+389', не правиме промени |
| 79 | IF LEFT(NEW.phoneNumber, 4) = '+389' THEN |
| 80 | RETURN NEW; |
| 81 | END IF; |
| 82 | |
| 83 | -- Ако бројот започнува со '389' и нема '+', додај само '+' |
| 84 | IF LEFT(NEW.phoneNumber, 3) = '389' THEN |
| 85 | NEW.phoneNumber := '+389' || SUBSTRING(NEW.phoneNumber FROM 4); |
| 86 | ELSE |
| 87 | -- Ако бројот не започнува со '389', додадете целосен префикс '+389' |
| 88 | NEW.phoneNumber := '+389' || NEW.phoneNumber; |
| 89 | END IF; |
| 90 | |
| 91 | -- Осигурување дека нема водечка '0' после '+389' |
| 92 | IF LEFT(NEW.phoneNumber, 4) = '+389' AND SUBSTRING(NEW.phoneNumber FROM 5 FOR 1) = '0' THEN |
| 93 | NEW.phoneNumber := '+389' || SUBSTRING(NEW.phoneNumber FROM 6); |
| 94 | END IF; |
| 95 | |
| 96 | RETURN NEW; |
| 97 | END; |
| 98 | $$ LANGUAGE plpgsql; |
| 99 | |
| 100 | |
| 101 | |
| 102 | |
| 103 | |
| 104 | |
| 105 | CREATE TRIGGER trigger_format_phone_number |
| 106 | BEFORE INSERT OR UPDATE ON vet_centers |
| 107 | FOR EACH ROW |
| 108 | EXECUTE FUNCTION format_phone_number(); |
| 109 | }}} |