Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Prosty trigger wywala SYNTAX
Forum PHP.pl > Forum > Bazy danych > MySQL
Grzyw
Witam.
Raczkuję w triggerach.
Poniższy kod generuje błąd składni:
  1. CREATE TRIGGER worker_insert before INSERT ON worker FOR each row
  2. begin IF new.impression <1 OR new.impression>5 then
  3. call fail('Incorrect impression value');
  4. end IF;
  5. end

Dlaczego?
skowron-line
A wykonujesz go w phpMyadmin questionmark.gif
Grzyw
Cytat(skowron-line @ 8.07.2009, 11:49:14 ) *
A wykonujesz go w phpMyadmin questionmark.gif

Tak
skowron-line
To zmień sobie delimiter smile.gif z ; na jakiś inny i zobacz.
Grzyw
Cytat(skowron-line @ 8.07.2009, 11:51:07 ) *
To zmień sobie delimiter smile.gif z ; na jakiś inny i zobacz.


Idąc za tutorialem wrzuciłem:
  1. delimiter //
  2. CREATE TRIGGER worker_insert before INSERT ON worker
  3. FOR each
  4. ROW
  5. BEGIN IF new.impression <1 OR new.impression >5
  6. THEN call fail('Incorrect impression value')
  7. END IF;
  8. END;//
  9. delimiter ;


Nadal SYNTAX:(
skowron-line
A pokaż błąd.
I czy po
Kod
call fail('Incorrect impression value')

nie powinno być ;

EIDT:
Albo zobacz jeszcze tak.
  1. delimiter //
  2. CREATE TRIGGER worker_insert before INSERT ON nazwa_bazy_danych.worker
  3. FOR each
  4. ROW
  5. BEGIN IF new.impression <1 OR new.impression >5
  6. THEN call fail('Incorrect impression value')
  7. END IF;
  8. END;//
  9. delimiter ;
Grzyw
Dzięki, spróbuję, jak tylko wstanie z powrotem, jednym z zapytań zamuliłem serwer....

Poszła pierwotna wersja, ale bezpośrednio w konsoli mysql.
Dzięki za pomoc.
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.