Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MySQL][PHP] Segregowanie rekordów w grupy
Forum PHP.pl > Forum > Przedszkole
oomaster
Witam,

Wyszukiwarka forum milczy na ten temat ale do rzeczy. Potrzebuje jakiegoś punktu podparcia jak to zrealizować. Przykładowo mam bazę:

Cytat
kat | tytul
1 | cos tam
3 | kolejny
2 | następny
1 | któryś tam
3 | dalszy


I chciałbym aby to tak się wyświetliło:

1
cos tam
któryś tam

2
następny

3
kolejny
dalszy


Oczywiście wszystko z jednego zapytanie jak to zrobić ? Jakich funkcji php i mysql użyć ?
piotrooo89
GROUP BY
vokiel
@piotrooo89 a czy przypadkiem GROUP BY nie zwróci mu tylko:
Kod
1 | cos tam
2 | następny
3 | dalszy


Może ORDER BY?
  1. SELECT * FROM `tabela` ORDER BY `kat`
oomaster
No dobra ale jak teraz w php załatwić problem pobrania 1,2,3 jako kategorii wyświetlenia jej i przypisania do niej odpowiednich rekordów tak jak przykładowo napisałem w przykładzie ?
thek
Posortuj według nazwy kategorii ( ORDER BY) i pobierz rekordy. Po stronie PHP rozpoznawaj kiedy przetwarzany rekord posiada inną nazwę kategorii niż rekord poprzedni. Jeśli są różnice - wyświetl nazwę czy co tam chcesz... Jak to zrobić? A mniej więcej tak...
  1. $res = mysql_query( 'SELECT nazwy_kolumn, kategoria FROm tabela ORDER BY kategoria' );
  2. $kategoria = '';
  3. while( $row = mysql_fetch_assoc( $res ) ) {
  4. if( $row['kategoria'] != $kategoria ) {
  5. $kategoria = $row['kategoria'];
  6. echo $kategoria.'<br />';
  7. }
  8. //rekordy
  9. }
Zaznaczam, że to skrót, ale tak mniej więcej wygląda schemat. Oczywiście tak to wygląda jeśli robisz mieszanie html i php, czego nie lubię. Osobiście w podobnej do powyższej pętli zrobiłbym (i robię tak) tablicę o strukturze:
  1. $tablica = array ( '1' => array( 'pierwszy', 'drugi' ), '2' => array('trzeci', 'czwarty'), '3' => array( 'piąty' ) );
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.