Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: zapytanie
Forum PHP.pl > Forum > Bazy danych
Norbit_24
Witam

Mam takie zapytanie:

  1. $zapytanie = mysql_query("SELECT * FROM tabela WHERE `cos`='cos' ORDER BY RAND() LIMIT 1") or die ("Błąd w zapytaniu");


Działa ok. Wyciaga 1 losowy rekord.
Ale chciałbym zrobić tak:
Mam w bazie ponad 30rekordów.
I chcę pobrać 10 z nich sprtowaniem ORDER BY id DESC, nastepnie wylosować [ORDER BY RAND()] z tych dziesięciu jeden i go pobrać.

Czy jest to możliwe?
Wicepsik
  1. SELECT * FROM tabela WHERE id IN(SELECT id FROM tabela DESC LIMIT 10) ORDER BY RAND() LIMIT 1


Nie sprawdzałem czy działa.
Norbit_24
SELECT * FROM tabela WHERE id IN(SELECT id FROM tabela DESC LIMIT 10) ORDER BY RAND() LIMIT 1

trzeba dodać jeszcze do tego WHERE cos='cos' tak jak podąłem w przykładzie
Wicepsik
  1. SELECT * FROM tabela WHERE cos = 'cos' AND id IN(SELECT id FROM tabela DESC LIMIT 10) ORDER BY RAND() LIMIT 1
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.