Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Kasowanie rekordów z drugiej tabeli
Forum PHP.pl > Forum > Bazy danych
L_Devil
Witam!

Mam dwie tabele:

Kod
TABELA 1
+-------+-----------+----------+----------+
|  id   |   owner   |   name   |   value  |
+-------+-----------+----------+----------+
|  1    |    1      |  obrazek | obraz.jpg|
|  2    |    1      |  atrybut | jpeg     |
|  3    |    1      |  costam  | wartosc  |
|  4    |    2      | rekord   | wartosc  |
+-------+-----------+----------+----------+

TABELA 2
+-------+-----------+----------+----------+
|  id   |   owner   |   name   |   value  |
+-------+-----------+----------+----------+
|  1    |    1      |  obrazek | obraz.jpg|
|  2    |    1      |  atrybut | jpeg     |
|  3    |    2      |  costam  | wartosc  |
|  4    |    3      | rekord   | wartosc  |
|  5    |    4      | rekord2  | wartosc2 |
+-------+-----------+----------+----------+
Chcę teraz usunąć rekordy z obu tabeli, ale uwaga: Chcę usunąć wszystkie wpisy z pierwszej tabeli dla konkretnej wartości pola owner i wszystkie wpisy z drugiej tabeli, której owner jest identyczny z przynajmniej jednym z id z kasowanych rekordów. Brzmi to trochę zagmatwanie, więc wyjaśnimy sytuację:

Kasuję rekordy o owner = 1:
Z pierwszej tabeli wylatują rekordy o id 1, 2, 3
Z drugiej tabeli wylatują rekordy o polu owner równym 1, 2, 3 (=wartości skasowanych id z pierwszej tabeli) - czyli pola o id 1, 2, 3, 4
W sumie kasuję 7 rekordów z dwóch tabel

O ile usuwanie z pierwszej tabeli to banał - polecenie
  1. DELETE
  2. FROM tabela1
  3. WHERE owner=1
i po problemie. Ale z jednoczesnym kasowaniem z drugiej tabeli nie umiem sobie poradzić
NuLL
Jaki masz serwer baz danych moze bys napisal :?:
L_Devil
MySQL smile.gif
DeyV
wersja?

Jeśli 5 - to chyba możesz skorzystać z trigerów, jeśli starsza - czy to nie czas na przesiadkę na Postgresa?
phobos
  1. DELETE tabela1, tabela2
  2. FROM tabela1,
  3. tabela2 WHERE tabela1.owner=1 AND tabela2.owner=tabela1.id;

albo
  1. DELETE
  2. FROM tabela1,
  3. tabela2 USING tabela1, tabela2 WHERE tabela1.owner=1 AND tabela2.owner=tabela1.id

2 dziala na 100% a pierwsze nie wiem bo nie urzywam czesto tongue.gif
L_Devil
Niestety 4.1 - a co do przesiadki mam bardzo ograniczone możliwości w tym względzie

Oba przykłady działają, ALE działają tylko dla rekordów które mają przynajmniej 1 odpowiednik w drugiej tabeli. Tymczasem część rekordów z pierwszej nie ma takich odpowiednich rekordów - wtedy dane z nich nie są kasowane
phobos
mozesz zrobic jeszcze tak
  1. DELETE
  2. FROM tabela1
  3. WHERE owner=1;
  4. DELETE
  5. FROM tabela2
  6. USING tabela1, tabela2 WHERE tabela2.owner!=tabela1.id;

ALE
musisz miec kazdy odpowiednik id z tabeli1 w tabeli2 w polu owner bo inaczej :
jak masz w tabeli2 pole owner=8 i nie bedziesz mial w tabeli1 id=8 to to tez usunie
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.