Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [PostgreSQL] - delete error?
Forum PHP.pl > Forum > Bazy danych
milk
HEY!
Ponizej wklejam błąd jaki otrzymuje podczas próby usunięcia 1 rekordu z tabeli news.
Kazdy news moze byc komentowany -> w tym przypadku ten news posiada komentarze.

Jak jednym zapytaniem usunąć news`a z tabeli news oraz wszystkie powiazane z nim komentarze?

Czy ten błąd będzie występował tylko w PostgreSQL czy w mySQL również?

  1. [b]Błąd SQL:
  2. [/b]
  3. ERROR: UPDATE OR DELETE ON TABLE "news" violates FOREIGN KEY constraint "comments_id_news_fkey" ON TABLE "comments"
  4. DETAIL: KEY (id_news)=(6) IS still referenced FROM TABLE "comments".
  5.  
  6. W poleceniu:
  7. DELETE FROM news WHERE id_news=6;


PROSZĘ O POMOC!
nospor
Z posgre u mnie krucho, ale komunikat bledu wyraźnie mówi, że masz powiązania tabeli comments z tym newsem. Masz zalożone takie powiązania, ze baza nie pozwala ci usunac newsa, który ma komentarze. Musisz najpierw usunac komentarze a potem newsa.
phpion
Najlepiej gdybyś w więzach integralności w tabeli comments dla kolumny id_news (chyba tak się nazywa) ustalił ON DELETE CASCADE. Wówczas w przypadku usuwania newsów automatycznie usuną Ci się komentarze do nich przypisane.

Na razie wykonaj to sobie dwoma zapytaniami (jak sugeruje ~nospor), czyli:
  1. DELETE FROM comments WHERE id_news=6;
  2. DELETE FROM news WHERE id_news=6;
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.