Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> Prosty trigger wywala SYNTAX
Grzyw
post
Post #1





Grupa: Zarejestrowani
Postów: 561
Pomógł: 75
Dołączył: 19.08.2004
Skąd: Wrocław

Ostrzeżenie: (0%)
-----


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?
Go to the top of the page
+Quote Post
skowron-line
post
Post #2





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

Ostrzeżenie: (0%)
-----


A wykonujesz go w phpMyadmin (IMG:http://forum.php.pl/style_emoticons/default/questionmark.gif)
Go to the top of the page
+Quote Post
Grzyw
post
Post #3





Grupa: Zarejestrowani
Postów: 561
Pomógł: 75
Dołączył: 19.08.2004
Skąd: Wrocław

Ostrzeżenie: (0%)
-----


Cytat(skowron-line @ 8.07.2009, 11:49:14 ) *

Tak
Go to the top of the page
+Quote Post
skowron-line
post
Post #4





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

Ostrzeżenie: (0%)
-----


To zmień sobie delimiter (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) z ; na jakiś inny i zobacz.
Go to the top of the page
+Quote Post
Grzyw
post
Post #5





Grupa: Zarejestrowani
Postów: 561
Pomógł: 75
Dołączył: 19.08.2004
Skąd: Wrocław

Ostrzeżenie: (0%)
-----


Cytat(skowron-line @ 8.07.2009, 11:51:07 ) *
To zmień sobie delimiter (IMG:http://forum.php.pl/style_emoticons/default/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:(

Ten post edytował Grzyw 8.07.2009, 10:59:15
Go to the top of the page
+Quote Post
skowron-line
post
Post #6





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

Ostrzeżenie: (0%)
-----


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 ;


Ten post edytował skowron-line 8.07.2009, 11:03:10
Go to the top of the page
+Quote Post
Grzyw
post
Post #7





Grupa: Zarejestrowani
Postów: 561
Pomógł: 75
Dołączył: 19.08.2004
Skąd: Wrocław

Ostrzeżenie: (0%)
-----


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.

Ten post edytował Grzyw 8.07.2009, 11:29:26
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 24.08.2025 - 19:34