• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Sortowanie, wyświetlanie galerii PHP SQL

Object Storage Arubacloud
–1 głos
285 wizyt
pytanie zadane 15 listopada 2016 w PHP przez ck Obywatel (1,780 p.)

Sortowanie według nazwy i daty działa według loginu już nie i nie bardzo wiem dlaczego. 

 

<?PHP
require_once "polacz.php";
		$polaczenie = new mysqli($host, $b_user, $b_password, $b_name);
			if ($polaczenie->connect_errno!=0) {
				echo "Error: ".$polaczenie->connect_errno."Opis: ".$polaczenie->connect_error;
			}
				
			$result = $polaczenie->query("SELECT users.login,albumy.tytul,albumy.data,albumy.id,albumy.id_users,images.id_albumu,count(images.id) as ile FROM (albumy
	left join images on albumy.id=images.id_albumu)
	left JOIN users on albumy.id_users=users.id
	GROUP by albumy.id HAVING ile>0");

			if (isset($_POST['nazwa_zdjecia'])) {
				$result = $polaczenie->query("SELECT * FROM albumy ORDER BY tytul ASC");
			} else if (isset($_POST['data_dodania'])) {
				$result = $polaczenie->query("SELECT * FROM albumy ORDER BY data DESC");
			} else if (isset($_POST['user'])) {
				$result = $polaczenie->query("SELECT * FROM albumy, users WHERE albumy.id_users = users.id ORDER BY users.login");
			} 

			while($row=$result->fetch_assoc()){
				$o .=  ' <div class="album"> <a href="album.php?id'.$row['id'].'"> <img src="img/'.$row['id'].'" height="180px" width="180px" title="Nazwa: '.$row['tytul'].' Autor: '.$row['login'].' Data: '.$row['data'].'" > </div>';
			}
?>

 

komentarz 15 listopada 2016 przez xandros Nałogowiec (29,450 p.)
Tak btw: zapomniales zamknac taga <a>
komentarz 15 listopada 2016 przez xandros Nałogowiec (29,450 p.)

Tak poza pytaniem:

  • sortowanie powinno odbywać się poprzez metodę GET, tak, aby user mógł skopiować sortowanie przez url i pokazać komuś innemu.
  • pierwsze query (to długie) powinieneś wykonać w momencie, jak żaden z warunków nie będzie spełniony. Zaoszczędzi to czas na zbyteczne query.
  • zamiast isset powinno być empty. Polecam użyć jakiegoś walidatora np.: http://respect.github.io/Validation/docs/trueval.html

1 odpowiedź

0 głosów
odpowiedź 15 listopada 2016 przez ck Obywatel (1,780 p.)
 
Najlepsza

dobra poradziłem sobie, wystarczyło dodać tablice z obrazkami i porównać id kod powinien wyglądać tak 

SELECT * FROM albumy, users, images WHERE albumy.id_users = users.id AND images.id_albumu=albumy.id ORDER BY users.login

 

1
komentarz 15 listopada 2016 przez efiku Szeryf (75,160 p.)

Niespodzianka!

Może zamiast SELECT * to pisz dokładnie to co chcesz pobrać? ;) (id,tytul,login,data) 

Podobne pytania

0 głosów
3 odpowiedzi 332 wizyt
pytanie zadane 3 lipca 2016 w SQL, bazy danych przez niezalogowany
0 głosów
0 odpowiedzi 157 wizyt
pytanie zadane 22 listopada 2019 w SQL, bazy danych przez antypop Mądrala (5,730 p.)
0 głosów
1 odpowiedź 222 wizyt
pytanie zadane 22 lutego 2017 w SQL, bazy danych przez kacperl95 Obywatel (1,980 p.)

92,583 zapytań

141,433 odpowiedzi

319,668 komentarzy

61,966 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...