Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> sortowanie po klknięciu w nagłówek tabeli
szpula
post
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]
Go to the top of the page
+Quote Post
mike
post
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.
Go to the top of the page
+Quote Post
lukaswoj
post
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
Go to the top of the page
+Quote Post
kszychu
post
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.
Go to the top of the page
+Quote Post
szpula
post
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ą.
Go to the top of the page
+Quote Post
mike
post
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.
Go to the top of the page
+Quote Post
szpula
post
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
Go to the top of the page
+Quote Post
kszychu
post
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]
Go to the top of the page
+Quote Post
mike
post
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 :?:
Go to the top of the page
+Quote Post
szpula
post
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]
Go to the top of the page
+Quote Post
Jojo
post
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
Go to the top of the page
+Quote Post
kszychu
post
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.
Go to the top of the page
+Quote Post
szpula
post
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.
Go to the top of the page
+Quote Post
szpula
post
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...
Go to the top of the page
+Quote Post
cboot
post
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)
Go to the top of the page
+Quote Post

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

 



RSS Aktualny czas: 23.08.2025 - 16:49