Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: trigger - problem
Forum PHP.pl > Forum > Bazy danych > MySQL
stal-sw
Witam.
Mam w bazie danych 2 tabele:

OCENY:
id, user_id, obiekt_id, srednia_ocena

OBIEKTY
id, nazwa, srednia_ocena

W tabeli OCENY uzytkownicy dodaja sobie oceny obiektow - podczas dodania rekordu do tej tabeli za pomoca php robie update sredniej oceny z wszystkich dokonanych ocen dla danego obiektu (lacznei z nowym wpisem) do tabeli OBIEKTY - i robie udpate pola srednia_ocena.

Jak zrobic tak ze podczas kasowania rekordu w tabeli OCENY (czy to za pomoca php czy za pomoca phpmyadmina) od nowa wyliczyc srednia dla OBEIKTU (o kasowanym - obiekt_id) i wprowdzic wartosc do pola srednia_ocena w tabli OBIEKTY.

W taki sposob robie obliczenia podczas dodawania nowej oceny do bazy za pomoca php:
  1. $ocsrednia = $db->get_row("SELECT TRUNCATE(AVG(ocena),4) as srednia FROM oceny WHERE id_obiektu='".$id_obiektu."' ");
  2. $db->query("UPDATE OBIEKTY SET ocsrednia='".$ocsrednia->srednia."' WHERE id='".$id_obiektu."'");



Teraz chcialbym zrobic cos podobnego przy uzyciu tylko bazy danych - i zeby to odbywalo sie zawsze podczas kasowania rekordu w tabeli OCENY (tylko obliczenia maja byc dokonywane wylacznie dla kasowanego OBIEKT_ID gory dzieki za pomoc
stal-sw
Witam.
Na razie udalo sie sklecic cos takiego:

  1.  
  2. DROP TRIGGER IF EXISTS `trig_przelicz_ocena`;
  3. delimiter //
  4. CREATE `trig_przelicz_ocena`
  5. AFTER DELETE ON `oceny` FOR EACH ROW
  6. BEGIN
  7. ................. questionmark.gif
  8.  
  9. UPDATE `obiekty`
  10. questionmark.gifquestionmark.gifquestionmark.gifquestionmark.gifquestionmark.gif?
  11. WHERE id = obiekt_id;
  12. END//

Dalej nie mam pojecia jak zrobic moj przyklad - chocaiz przegladnalem juz troche gotowcow troggerow sad.gif
alegorn
tak, mozemy to zrobic za ciebie, ale ja za przykladem kolegi - dam ci wedke :]

zainstaluj sobie przykladowa baze danych sakila (chocby tutaj: mysql-sakila )

masz tam przyklady ciekawych rozwiazan, takze triggerow, mysle ze wiekszosc watpliwosci to pomoze rozwiazac..
j.
stal-sw
Witam.
A moze da sie to zrobic w takim stylu ?

  1. DROP TRIGGER IF EXISTS przelicz_oceny;
  2. delimiter $$
  3. CREATE TRIGGER przelicz_oceny
  4. AFTER DELETE ON oceny
  5. FOR EACH ROW
  6. BEGIN
  7.  
  8. UPDATE obiekty SET osrednia=(SELECT TRUNCATE(AVG(ocena),4) FROM oceny WHERE id_obiektu=$id_obiektu) WHERE id=$id_obiektu
  9.  
  10. END$$
  11. delimiter ;
nospor
Jak ty żeś czytał o tych triggerach? Przecież dość wyrażnie jest tam wspomniane o NEW oraz OLD, które to przechowuję informacje, których szukasz...
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.