Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> sortowanie tablicy, która funkcja?
Thuunder
post
Post #1





Grupa: Zarejestrowani
Postów: 234
Pomógł: 1
Dołączył: 29.10.2004

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


Witam,
Mam dane z bazy w tablicy w postaci
  1. <?php
  2. $tablica[0]['imie']
  3. $tablica[0]['nazwisko']
  4. $tablica[0]['uwagi']
  5. $tablica[1]['imie']
  6. $tablica[1]['nazwisko']
  7. $tablica[1]['uwagi']
  8. ?>

i chciałbym ją posortować raz po nazwisku, a raz po imieniu. W jaki sposób?


--------------------
najprostsze rzeczy są najmniej oczywiste
Go to the top of the page
+Quote Post
nospor
post
Post #2





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




W manualu masz to ladnie opisane. Wystarczy przeczytac dokladnie calosc
http://pl2.php.net/manual/pl/function.array-multisort.php


--------------------

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

Go to the top of the page
+Quote Post
Zyx
post
Post #3





Grupa: Zarejestrowani
Postów: 952
Pomógł: 154
Dołączył: 20.01.2007
Skąd: /dev/oracle

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


Co rozumiesz przez pojęcie "raz po imieniu a raz po nazwisku"? Chodzi o możliwość wyboru, względem czego sortować? Po stronie PHP myślę, że bardziej nada się tu funkcja usort(), gdzie możesz zaproponować własną funkcję porównującą elementy:

  1. <?php
  2. function porownywanie($a, $b)
  3. {
  4.  return strcmp($a['imie'], $b['imie']);
  5. }
  6.  
  7. usort($tablica, 'porownywanie');
  8. ?>


Używając kilku funkcji lub konfigurowalnej klasy, możesz w ten sposób zrobić sortowanie względem normalnego pola. Mimo to polecałbym jednak takie operacje robić już na etapie pobierania danych z bazy, gdzie takie sortowanie może być dużo szybsze dzięki indeksom.


--------------------
Specjalista ds. głupich i beznadziejnych, Zyx
Nowości wydawnicze: Open Power Collector 3.0.1.0 | Open Power Autoloader 3.0.3.0
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 21.08.2025 - 06:36