![]() |
![]() ![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 60 Pomógł: 0 Dołączył: 24.05.2004 Ostrzeżenie: (0%) ![]() ![]() |
Jak najprościej zrobić żeby po kliknieciu w nagłówki poszczególnych tabel (l.p, marka, rok produkcji) sortowało mi dane np.: rosnąco?(IMG:http://forum.php.pl/style_emoticons/default/questionmark.gif)
Oto kod który wyświetla mi spis aut w komisie: [php:1:f6927a72f3]<?php <?php <td><p align="center">L.p</td> <td><p align="center"><Marka</td> <td><p align="center"><Rok produkcji</td> $zapytanie = "SELECT auto_id , marka_nazwa, rok_nazwa FROM auta, marka, rok WHERE marka.marka_id=auto_marka_id and and rok.rok_id=auto_rok_id "; $wykonaj = mysql_query ($zapytanie); echo($wykonaj); while($wiersz=mysql_fetch_array ($wykonaj)) { echo "<tr align=center> <td>".$wiersz['auto_id']."</td> <td>".$wiersz['marka_nazwa']."</td> <td>".$wiersz['rok_nazwa']."</td> </tr>"; } ?> ?>[/php:1:f6927a72f3] |
|
|
![]()
Post
#2
|
|
Grupa: Przyjaciele php.pl Postów: 7 494 Pomógł: 302 Dołączył: 31.03.2004 Ostrzeżenie: (0%) ![]() ![]() |
Ogólnie to ma to wyglądać tak :
1. Przy nagłówkach tabel daj linki rosnąco i malejąco w każdej tabeli; linki te będą wysyłały dwie zmienne : wg. której kolumny sortujemy, i jak (ASC/DESC); 2. w zapytaniu którym wybierasz dane z bazy wstaw watrości zmiennych, które przyjdą z $_GET; np.: $order_by i $sort (ASC/DESC); To w ogólnym skrócie. |
|
|
![]()
Post
#3
|
|
Grupa: Zarejestrowani Postów: 136 Pomógł: 0 Dołączył: 2.01.2004 Skąd: Lublin Ostrzeżenie: (0%) ![]() ![]() |
Pomyśleć chwilke ;-)
Niech tytuł każdej z tabel będzie linkiem na końcu, którego dopisujesz zmienna o jakiejś nazwie z wartością, za pomocą którą zaidentyfikujesz kolumnę. Np: Kod <a href="balblabla.php?sort=tytul">Tytul</a>
Gdzieś tam w kodzie przed generowanie zapytania sprawdzaj, czy było rządanie sortowania kolumny, czyli czy zmienna $_GET{'sort'} ma jakąłś wartość i czy jest to jedna z nazw kolumn no i potem zastosuj to odpowiednio w zapytaniu w klauzuli "ORDER BY". Tyle |
|
|
![]()
Post
#4
|
|
Grupa: Przyjaciele php.pl Postów: 2 712 Pomógł: 23 Dołączył: 27.10.2003 Skąd: z kontowni Ostrzeżenie: (0%) ![]() ![]() |
Najprościej (co nie znaczy najbezpieczniej) to tak
[php:1:1173b2518c]<?php <?php <td><p align="center">L.p</td> <td><p align="center"><a href=$PHP_SELF?order=marka>Marka</a></td> <td><p align="center"><a href =$PHP_SELF?order=rok_nazwa>Rok produkcji</a></td> $zapytanie = "SELECT auto_id , marka_nazwa, rok_nazwa FROM auta, marka, rok WHERE marka.marka_id=auto_marka_id and and rok.rok_id=auto_rok_id ORDER BY ".$order; $wykonaj = mysql_query ($zapytanie); echo($wykonaj); while($wiersz=mysql_fetch_array ($wykonaj)) { echo "<tr align=center> <td>".$wiersz['auto_id']."</td> <td>".$wiersz['marka_nazwa']."</td> <td>".$wiersz['rok_nazwa']."</td> </tr>"; } ?> ?>[/php:1:1173b2518c][/quote] Oczywiście zamiast jawnie podanych nazw kolumn w linku można zastosować znaczniki typu 1, 2 ,3 a później w skrypcie zastosować switch i jeśli 1 to order by marka, 2 - rok itp. Oczywiście nie uwzględniam tu też parametru register globals. |
|
|
![]()
Post
#5
|
|
Grupa: Zarejestrowani Postów: 60 Pomógł: 0 Dołączył: 24.05.2004 Ostrzeżenie: (0%) ![]() ![]() |
Coś nie chce mi teraz łączyć się z bazą. Jak usunę ten zapis:
[php:1:0cde504913]<?php ORDER BY ".$order; ?>[/php:1:0cde504913] to wtedy jest połączenie z bazą. |
|
|
![]()
Post
#6
|
|
Grupa: Przyjaciele php.pl Postów: 7 494 Pomógł: 302 Dołączył: 31.03.2004 Ostrzeżenie: (0%) ![]() ![]() |
Na czy polega błąd, jaki wywala komunikat :?:
P.S. Musisz dać jakąś wartość odmyślną dla $order, bo przy pierwszym wejściu na stronę zapytanie się posypie. |
|
|
![]()
Post
#7
|
|
Grupa: Zarejestrowani Postów: 60 Pomógł: 0 Dołączył: 24.05.2004 Ostrzeżenie: (0%) ![]() ![]() |
po prostu mam tylko nagłówki tabel , czyli nie połączył się z bazą , nie wypisuje wyników zapytania
|
|
|
![]()
Post
#8
|
|
Grupa: Przyjaciele php.pl Postów: 2 712 Pomógł: 23 Dołączył: 27.10.2003 Skąd: z kontowni Ostrzeżenie: (0%) ![]() ![]() |
Jak powiedział mike_mech, przed zapytaniem daj coś takiego:
[php:1:6923681a7a]<?php if (!isset($order)) $order = marka_nazwa; ?>[/php:1:6923681a7a] |
|
|
![]()
Post
#9
|
|
Grupa: Przyjaciele php.pl Postów: 7 494 Pomógł: 302 Dołączył: 31.03.2004 Ostrzeżenie: (0%) ![]() ![]() |
Skoro nie wywalił żadnego błędu to znaczy że się połączył tylko nie zwrócił żadnych wierszy w wyniku, albo masz tak gdzieś @ "zainstalowaną".
A masz jakąś wartość domyślną dla $order :?: |
|
|
![]()
Post
#10
|
|
Grupa: Zarejestrowani Postów: 60 Pomógł: 0 Dołączył: 24.05.2004 Ostrzeżenie: (0%) ![]() ![]() |
Nie rozumiem:( Powinno wypisywać a nie wypisuje.
Oto kompletny kod. zmieniam i zmieniam i ciągle nie wypisuje wierszy? może nie widze jakiegoś błędu?? Oto cały kod: [php:1:1d1c3a09d9]<?php <? mysql_connect ("localhost","baza","pass"); mysql_select_db ("amc_test"); echo("<td><p align="center">L.p</td> <td><p align="center"><a href=$PHP_SELF?order=marka_nazwa>Marka</a></td> <td><p align="center"><a href =$PHP_SELF?order=rok_nazwa>Rok produkcji</a></td>"); ?><? if (!isset($order)) $order = marka_nazwa; $zapytanie = "SELECT auto_id , marka_nazwa, rok_nazwa FROM auta, marka, rok WHERE marka.marka_id=auto_marka_id and and rok.rok_id=auto_rok_id ORDER BY ".$order; $wykonaj = mysql_query ($zapytanie); echo($wykonaj); while($wiersz=mysql_fetch_array ($wykonaj)) { echo "<tr align=center> <td>".$wiersz['auto_id']."</td> <td>".$wiersz['marka_nazwa']."</td> <td>".$wiersz['rok_nazwa']."</td> </tr>"; } ?> ?>[/php:1:1d1c3a09d9] |
|
|
![]()
Post
#11
|
|
Grupa: Zarejestrowani Postów: 405 Pomógł: 1 Dołączył: 19.09.2003 Skąd: Lublin Ostrzeżenie: (0%) ![]() ![]() |
Nie podoba mi się Twoje zapytanie. Po pierwsze czemu w warunkach masz dwa "AND" pod rząd? Po drugie musisz po SELECT napisać nazwy pól razem z tabelami, z których je wybierasz czyli na przykład marka.marka_nazwa
|
|
|
![]()
Post
#12
|
|
Grupa: Przyjaciele php.pl Postów: 2 712 Pomógł: 23 Dołączył: 27.10.2003 Skąd: z kontowni Ostrzeżenie: (0%) ![]() ![]() |
Cytat Po drugie musisz po SELECT napisać nazwy pól razem z tabelami, z których je wybierasz czyli na przykład marka.marka_nazwa
Jeśli nazwy pól nie powtarzają się w innych tabelach złączonych w zapytaniu to nie musi. |
|
|
![]()
Post
#13
|
|
Grupa: Zarejestrowani Postów: 60 Pomógł: 0 Dołączył: 24.05.2004 Ostrzeżenie: (0%) ![]() ![]() |
z tym and -em to nie wiem jak mogłem nie zauważyć, a co do kropek to zgadzam się że nie muszą być. Chyba wszystko teraz działa. Właśnie sprawdzam.
|
|
|
![]()
Post
#14
|
|
Grupa: Zarejestrowani Postów: 60 Pomógł: 0 Dołączył: 24.05.2004 Ostrzeżenie: (0%) ![]() ![]() |
Dzięki chlopaki za pomoc!
pododawałem troche parametrów i wszystko działa tylko nie sortowało mi tabeli cena poprawnie, bo miałem pole w bazie jako char a trzeba było zmienic na int. A czy jest taka możliwośc żeby po kliknięciu na link poraz drugi sortowalo malejąco?? Na zmiane. Raz rosnąco, klikamy- malejąco, klikamy-rosnąco -itd... |
|
|
![]()
Post
#15
|
|
Grupa: Zarejestrowani Postów: 85 Pomógł: 0 Dołączył: 2.02.2004 Ostrzeżenie: (0%) ![]() ![]() |
To:
[php:1:b2d73a580e]<?php echo("<td><p align="center">L.p</td> <td><p align="center"><a href=$PHP_SELF?order=marka_nazwa>Marka</a></td> <td><p align="center"><a href =$PHP_SELF?order=rok_nazwa>Rok produkcji</a></td>"); ?>[/php:1:b2d73a580e] Należy rozwinąc tak: [php:1:b2d73a580e]<?php if (!isset($sort)) $sort = 'asc'; if ( $order == 'marka_nazwa' && $sort == 'asc') { echo("<td><p align="center">L.p</td><td><p align="center"><a href=$PHP_SELF?order=marka_nazwa&order=desc>Marka</a></td>") } else { echo("<td><p align="center">L.p</td><td><p align="center"><a href=$PHP_SELF?order=marka_nazwa&order=asc>Marka</a></td>") } if ( $order == 'rok_nazwa' && $sort == 'asc') { echo("<td><p align="center"><a href =$PHP_SELF?order=rok_nazwa&sort=desc>Rok produkcji</a></td>"); } else { echo("<td><p align="center"><a href =$PHP_SELF?order=rok_nazwa&sort=asc>Rok produkcji</a></td>"); } ?>[/php:1:b2d73a580e] A w zapytaniu doklejasz w tym miejscu: [php:1:b2d73a580e]<?php "...ORDER BY ".$order; ?>[/php:1:b2d73a580e] Zmienną $sort [php:1:b2d73a580e]<?php "...ORDER BY ".$order." ".$sort; ?>[/php:1:b2d73a580e] Mogą być literówki, jak zwykle (IMG:http://forum.php.pl/style_emoticons/default/tongue.gif) |
|
|
![]() ![]() |
![]() |
Aktualny czas: 23.08.2025 - 16:49 |