Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [PHP] sąsiednie rekordy (prev i next)
brychu
post 24.07.2016, 01:23:16
Post #1





Grupa: Zarejestrowani
Postów: 61
Pomógł: 0
Dołączył: 10.04.2015

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


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]';

Go to the top of the page
+Quote Post
Pyton_000
post 24.07.2016, 06:54:30
Post #2





Grupa: Zarejestrowani
Postów: 8 068
Pomógł: 1414
Dołączył: 26.10.2005

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


Temat: Najczestsze bledy
Go to the top of the page
+Quote Post
Lion
post 24.07.2016, 19:17:13
Post #3





Grupa: Zarejestrowani
Postów: 148
Pomógł: 14
Dołączył: 23.02.2013

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


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.


--------------------
Go to the top of the page
+Quote Post
brychu
post 24.07.2016, 22:25:19
Post #4





Grupa: Zarejestrowani
Postów: 61
Pomógł: 0
Dołączył: 10.04.2015

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


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%">';
Go to the top of the page
+Quote Post
Rysh
post 24.07.2016, 22:26:50
Post #5





Grupa: Zarejestrowani
Postów: 821
Pomógł: 111
Dołączył: 11.09.2006
Skąd: Biała Podlaska

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


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


Ten post edytował Rysh 24.07.2016, 22:48:07


--------------------
Go to the top of the page
+Quote Post
Pyton_000
post 25.07.2016, 07:07:37
Post #6





Grupa: Zarejestrowani
Postów: 8 068
Pomógł: 1414
Dołączył: 26.10.2005

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


Bo dla ID 5 nie koniecznie następny to 6 a poprzedni to 4 wink.gif
Go to the top of the page
+Quote Post
Rysh
post 25.07.2016, 07:14:13
Post #7





Grupa: Zarejestrowani
Postów: 821
Pomógł: 111
Dołączył: 11.09.2006
Skąd: Biała Podlaska

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


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ć.


--------------------
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 Wersja Lo-Fi Aktualny czas: 18.06.2025 - 15:28