Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Zapytanie zliczające
Forum PHP.pl > Forum > Bazy danych > MySQL
loczek111
Witam,
Mam tabelę w bazie mysql

id --- tresc --- nr
1 --- abcd ---- 5
2 --- efgh ---- 0
3 --- ijkly ---- 2
4 --- mnop ---- 5
5 --- rstuw ---- 0

Wynikiem zapytania chcę osiągnąć następujący rezultat
id --- tresc --- zliczone
1 --- abcd ---- 0
2 --- efgh ---- 1
3 --- ijkly ---- 0
4 --- mnop ---- 0
5 --- rstuw ---- 2

Wybaczcie że tak wprost pytam ale wydaje mi się że to nic trudnego a nie mogę dojść do rozwiązania.
trueblue
Czym jest wartość zliczone?
loczek111
Myślałem że przykład to zilustruje, kolumna 'zliczone' zawiera wartości ile razy występuje id danego rekordu w kolumnie 'nr'.
W moim projekcie wygląda to tak że wyświetlam wszystkie rekordy z nr = 0 , a te niezerowe to są odwołania do nich. Np. (co do mojego przykładu)
Wyświetlam rstuw(id =5) a obok liczbę jakby komentarzy (id 1 i 4 odwołuje się do id 5)
Pyton_000
Na szybko:
Kod
SELECT a.id, a.tresc, IFNULL(b.c,0) FROM tt2 a
LEFT JOIN (SELECT nr, COUNT(0) as c FROM tt2 GROUP BY nr) as b ON (a.id = b.nr)
trueblue
  1. SELECT t1.id, t1.tresc, t1.nr, COUNT(t2.nr) AS zliczone FROM tabela AS t1
  2. LEFT JOIN tabela AS t2 ON t2.nr=t1.id
  3. GROUP BY t1.id, t2.nr

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.