stworzyłem taki prosty trigger:
CREATE TRIGGER data_dodania
BEFORE INSERT ON pracownik
FOR EACH ROW update pracownik
SET imie = "Jan";
kiedy probuję dodać rekord np
INSERT INTO pracownik (id_pracownika) VALUES (1);
otrzymuje komunikat:
Error Code: 1442. Can't update table 'pracownik' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.
o co chodzi ?
a czy istnieje już rekord z id = 1?
CREATE TRIGGER data_dodania
after INSERT ON pracownik
FOR EACH ROW update pracownik
SET imie = "Jan";
i dodam id to taki sam komunikat się pojawia,
Error Code: 1442. Can't update table 'pracownik' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.
CREATE TABLE `pracownicy` ( `id` INT(11) NOT NULL AUTO_INCREMENT, `imie` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_520_ci', PRIMARY KEY (`id`) ) COLLATE='utf8_unicode_520_ci' ENGINE=InnoDB; CREATE TRIGGER `data_dodania` BEFORE INSERT ON `pracownicy` FOR EACH ROW begin SET NEW.imie = "Jan"; end
ok wiem o co chodzi z tymi new ale jak zrobić aby np. po aktualizacji jakiegoś rekordu, czy nawet dodaniu nowego rekordu, zmienić jakąś wartość w tablicy np. rekord którego id wynosi 3, który już jest w tablicy
DELIMITER |
create TRIGGER zmieniaImie after update ON pracownik
FOR EACH ROW
BEGIN
update pracownik SET imie="Ola" where id_pracownika=5;
END;
|
DELIMITER ;
takie coś nie działa, wyświetla się ten komunikat co w temacie
Nie możesz tego zrobić w mysql, bo jak pisałem, możesz powodować nieskończone zapętlenie albo deadlock. Zawsze możesz drugie zapytanie wykonać albo, w zależności od potrzeb, napisać ifa który zrobić coś na podstawie przychodzących wartości.
rozumiem, dzięki
Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)