Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [PHP] sąsiednie rekordy (prev i next)
Forum PHP.pl > Forum > Przedszkole
brychu
Potrzebuje wyciągać poprzedni i następny rekord. Tutaj mam kod, ale nie rozumiem jak go użyć.
  1. (SELECT id, 'prev' kol FROM tabela1 WHERE id < 5 order by id desc LIMIT 0, 1)
  2. UNION
  3. (SELECT id, 'next' kol FROM tabela1 WHERE id > 5 order by id asc LIMIT 0, 1)



Zrobić zapytanie do bazy? Próbowałem tak, ale oczywiście jest źle.
  1. $wynik2 = mysql_query(SELECT id, 'prev' kol FROM zdjecia WHERE id < 30 order by id desc LIMIT 0, 1)
  2. UNION
  3. (SELECT id, 'next' kol FROM zdjecia WHERE id > 30 order by id asc LIMIT 0, 1)
  4. or die('Błąd zapytania');
  5. echo $wynik2[kol]';

Pyton_000
Temat: Najczestsze bledy
Lion
Uruchom swoje zapytanie bezpośrednio w mysql. Może to coś Ci podpowie. Jak zapytanie będzie już działać to przeczytaj manual funkcji mysql_fetch_assoc.
brychu
No i wszystko jasne. Dzięki Panowie.
Działający kod:

  1. $id=$_GET['wyswietl'];
  2.  
  3. $poprz = mysql_query("SELECT * FROM `zdjecia` WHERE `id`>'{$id}' ORDER BY id ASC LIMIT 1");
  4. $poprz1=mysql_fetch_assoc($poprz);
  5.  
  6. $nast = mysql_query("SELECT * FROM `zdjecia` WHERE `id`<'{$id}' ORDER BY id DESC LIMIT 1");
  7. $nast1=mysql_fetch_assoc($nast);
  8.  
  9. echo '<a href="wyswietlaniezdjec.php?wyswietl='.$nast1[id].'">POPRZEDNIE</a>';
  10. echo '<a href="wyswietlaniezdjec.php?wyswietl='.$poprz1[id].'">NASTEPNE</a>';
  11.  
  12.  
  13.  
  14. $wynik = mysql_query("SELECT * FROM zdjecia WHERE id=$id") or die('Błąd zapytania');
  15. $r = mysql_fetch_assoc($wynik);
  16.  
  17.  
  18. echo '<img src="foto/'.$r[nazwa].'" width="100%">';
Rysh
Dlaczego nie zrobiłeś tego jednym zapytaniem? ohno-smiley.gif

Chociażby tak:
  1. SELECT primary_id FROM yourtable WHERE primary_id = {id}-1 OR primary_id = {id}+1
Pyton_000
Bo dla ID 5 nie koniecznie następny to 6 a poprzedni to 4 wink.gif
Rysh
Cytat(Pyton_000 @ 25.07.2016, 08:07:37 ) *
Bo dla ID 5 nie koniecznie następny to 6 a poprzedni to 4 wink.gif

Fakt z wieczora nie pomyślałem o tym, ale na pewno dałoby się to wyciągnąć jednym zapytaniem smile.gif spróbuję coś wymyślić.
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.