Foros del Web » Programación para mayores de 30 ;) » Bases de Datos General » Mysql »

Consulta random

Estas en el tema de Consulta random en el foro de Mysql en Foros del Web. Que tal buenas tardes, tengo una duda, requiero hacer una consulta para traer registros aleatorios de una tabla, mi problema es que cuando mando llamar ...
  #1 (permalink)  
Antiguo 10/02/2011, 18:49
 
Fecha de Ingreso: mayo-2009
Mensajes: 242
Antigüedad: 15 años
Puntos: 2
Pregunta Consulta random

Que tal buenas tardes, tengo una duda, requiero hacer una consulta para traer registros aleatorios de una tabla, mi problema es que cuando mando llamar esa consulta me vulve a repetir registros y lo que quiero es que en cada llamada a la consulta ya no me traiga registros que ya se mostraron.

Esta es mi consulta:

'SELECT * FROM anuncios ORDER BY RAND() LIMIT '.$inicio.','.$fin.''


De antemano gracias.
  #2 (permalink)  
Antiguo 11/02/2011, 21:20
Avatar de huesos52
Colaborador
 
Fecha de Ingreso: febrero-2009
Ubicación: Manizales - Colombia
Mensajes: 5.980
Antigüedad: 15 años, 2 meses
Puntos: 360
Respuesta: Consulta random

solo con mysql no podras resolverlo. es mas, por este lado eso es lo mas que podrías hacer.

saludos
__________________
Without data, You are another person with an opinion.
W. Edwads Deming
  #3 (permalink)  
Antiguo 11/02/2011, 21:42
Avatar de gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 16 años, 5 meses
Puntos: 2658
Respuesta: Consulta random

Cita:
Iniciado por kriss8725 Ver Mensaje
...lo que quiero es que en cada llamada a la consulta ya no me traiga registros que ya se mostraron.
Para lograrlo deberías determinar primero qué registros ya se mostraron.
Te sugiero crear una tabla temporal donde almacenes las PK de aquellos registros ya mostrados y hacer una consulta que los excluya, como:
Código MySQL:
Ver original
  1. FROM tabla
  2. WHERE tabla_id NOT IN (SELECT tabla_id FROM tablateporal)
  3. LIMIT 10;

(para mostrar los primeros diez)
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)

Etiquetas: random
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 18:30.