djszaki
25.02.2019, 22:53:08
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 ?
Tomplus
26.02.2019, 06:53:41
a czy istnieje już rekord z id = 1?
djszaki
26.02.2019, 07:32:27
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.
viking
26.02.2019, 07:59:45
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
To co robisz może prowadzić do nieskończonej pętli wewnątrz zapytania.
djszaki
26.02.2019, 09:51:07
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
viking
26.02.2019, 10:00:26
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.
djszaki
26.02.2019, 10:26:30
rozumiem, dzięki
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.