Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Liczenie wystąpień w 2 różnych sytuacjach[zdjecie]
Forum PHP.pl > Forum > Bazy danych > MySQL
RollDev
Witam, to znoau ja wink.gif

Napotkałem kolejny problem.
Mam 3 tabele. Arts, Artist i Arts_Artist jako relacja.
Do rekordu z Arts mogę przypisać dowolną ilość Artist i Artist może mieć wiele Arts'ów.
Chce teraz policzyć Ile Arts mają Artyści, lecz jest tutaj mały haczyk.
Arts może nie mieć odzwierciedlonej relacji w Arts_Artist, a w tabeli Arts ma pole "for_all_artist" - czyli dostępne dla wszystkich artystów.

Muszę policzyć ile Artist ma odzwierciedlen w Arts_Artis i policzyć do tego Arts, które są dostępne dla wszystkich.

Odzwiercidelić Wam to na prostej bazie?

@INFO W tabeli "ArtsArtis" mogę nie dopuścić do wystąpienia rekordu o ID 3. Także może powinno to jakoś ułatwić sprawę

trueblue
  1. SELECT id_artist, COUNT(id_arts)
  2. FROM(
  3.  
  4. SELECT a.id_artist,ar.id_arts
  5. FROM (artist AS a,arts_artist AS aa,arts AS ar)
  6. WHERE aa.id_artist=a.id_artist AND ar.id_arts=aa.id_arts
  7.  
  8. UNION
  9.  
  10. SELECT a.id_artist,ar.id_arts
  11. FROM (artist AS a,arts AS ar)
  12. WHERE ar.ALL=1
  13.  
  14. ) AS tmp
  15. GROUP BY id_artist
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.