Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> Struktura drzewiasta - pobranie rekordów, dla których Parent został usunięty?
miedzna
post
Post #1





Grupa: Zarejestrowani
Postów: 401
Pomógł: 1
Dołączył: 10.03.2004
Skąd: Warszawa

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


Nie wiem czy możliwe jest skonstruowanie zapytania, które z tabeli o układzie | id | pid | name | pobierze mi te rekordy, dla których pole pid (czyli parent) kiedyś istniał, pole jest wypełnione, ale teraz go nie ma w bazie, bo został usunięty. Chcę wyłapać te sieroty z bazy, co niby mają rodzica, ale tak naprawdę go nie mają. Da się to jakoś podejść jednym zapytaniem?

I jeszcze jedno pytanie, czy istnieje coś takiego, jakiś automat czy jak, że jeżeli usunę rekord z tabeli X, to automatycznie z tabeli Y zostanie usunięty powiązany z tabelą X rekord?

Ten post edytował miedzna 25.02.2009, 22:13:25
Go to the top of the page
+Quote Post
BaN
post
Post #2





Grupa: Zarejestrowani
Postów: 158
Pomógł: 43
Dołączył: 9.11.2007

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


Cytat(miedzna @ 25.02.2009, 22:12:04 ) *
Nie wiem czy możliwe jest skonstruowanie zapytania, które z tabeli o układzie | id | pid | name | pobierze mi te rekordy, dla których pole pid (czyli parent) kiedyś istniał, pole jest wypełnione, ale teraz go nie ma w bazie, bo został usunięty. Chcę wyłapać te sieroty z bazy, co niby mają rodzica, ale tak naprawdę go nie mają. Da się to jakoś podejść jednym zapytaniem?

Można np. tak:
  1. [SELECT t1.* FROM tabela AS t1 WHERE NOT EXISTS (SELECT 1 FROM tabela AS t2 WHERE t2.id=t1.pid)


Cytat(miedzna @ 25.02.2009, 22:12:04 ) *
I jeszcze jedno pytanie, czy istnieje coś takiego, jakiś automat czy jak, że jeżeli usunę rekord z tabeli X, to automatycznie z tabeli Y zostanie usunięty powiązany z tabelą X rekord?

Możesz zastosować klucz obcy i warunek ON DELETE CASCADE o ile baza na to pozwala, ewentualnie napisać trigger
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: 22.08.2025 - 16:12