Foros del Web » Programando para Internet » PHP »

como puede hacer este select en mysql

Estas en el tema de como puede hacer este select en mysql en el foro de PHP en Foros del Web. tengo un priblemita estoy programando un foro pero cuando quiero hacer un select para que me presente el ultimo mensaje de cada categoria no me ...
  #1 (permalink)  
Antiguo 06/06/2010, 00:10
Avatar de elchicho118  
Fecha de Ingreso: mayo-2010
Mensajes: 74
Antigüedad: 13 años, 11 meses
Puntos: 1
Pregunta como puede hacer este select en mysql

tengo un priblemita estoy programando un foro pero cuando quiero hacer un select
para que me presente el ultimo mensaje de cada categoria no me presenta el ultimo
por mas post que creo y por mas tema que creo no me presenta el ultimo
mi select es este:

$registro=mysql_query("select tema,autor,fecha,categoria
from temas group by categoria order by fecha desc ",$conexion)
or die("Problemas en el select".mysql_error());
  #2 (permalink)  
Antiguo 06/06/2010, 01:42
Avatar de mortiprogramador
Colaborador
 
Fecha de Ingreso: septiembre-2009
Ubicación: mortuoria
Mensajes: 3.805
Antigüedad: 14 años, 7 meses
Puntos: 214
Respuesta: como puede hacer este select en mysql

Hola
ya probaste ese select directamente en la bd?
saludos
__________________
"Si consigues ser algo más que un hombre, si te entregas a un ideal, si nadie puede detenerte, te conviertes en algo muy diferente."
Visita piggypon.com
  #3 (permalink)  
Antiguo 06/06/2010, 10:27
Avatar de wiwi74  
Fecha de Ingreso: marzo-2008
Mensajes: 515
Antigüedad: 16 años, 1 mes
Puntos: 10
Respuesta: como puede hacer este select en mysql

asi podrias hallar el ultimo elemento de una tabla:


Código PHP:

mysql_connect
("db","user","pass");
mysql_query("use db;");


//contamos las filas de la tabla
$registro=mysql_query("select count(*) from estados");
$r=mysql_fetch_array($registro);
//$r['count(*)'] contendra el numeto de filas
//echo "<lI>".$r['count(*)'];


//ahora recuperamos las fila que deseamos usando "limit" 
//escribiendo limit anteUltimaFila,y_ultima nos devolvera la ultima. 
//Dinamicamiete seria, usando $r['count(*)'] :
//limit ".($r['count(*)'] -1).",".$r['count(*)'].


$registro=mysql_query("select * from  estados limit ".($r['count(*)'] -1).",".$r['count(*)']."");
while(
$r=mysql_fetch_array($registro)){
echo 
"<lI>".$r['estado'];
}

//Resultado: Zaragoza 
  #4 (permalink)  
Antiguo 06/06/2010, 10:57
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, 4 meses
Puntos: 2658
Respuesta: como puede hacer este select en mysql

Es un problema de SQL, no de PHP, sería mejor tratarlo en el foro de BBDDD, pero te puedo adelantar algo;
El problema es que el ordenamiento es posterior a la agrupación, por lo que primero agrupa en el orden en que encuentra los registros y recién allí ordena. Eso hace que el primer registro encontrado "esconda" a los demás, y como el orden de lectura es el orden cronológico ascendente, el primero de la lista es el más viejo, no el mas nuevo.
La solución más sencilla es meter todo esto en una subconsulta, y que recién se agrupe en la exterior:
Código MySQL:
Ver original
  1. SELECT tema, autor, fecha, categoria
  2.   (SELECT tema, autor, fecha, categoria
  3.   FROM temas
  4.   ORDER BY fecha DESC)  T1
  5. GROUP BY categoria;

En PHP sería:
Código PHP:
Ver original
  1. $sql = "SELECT tema, autor, fecha, categoria"
  2. $sql .= "FROM"
  3. $sql .= "  (SELECT tema, autor, fecha, categoria"
  4. $sql .= "  FROM temas "
  5. $sql .= "  ORDER BY fecha DESC)  T1"
  6. $sql .= "GROUP BY categoria;"
  7.  
  8. $registro=mysql_query($sql,$conexion)
  9. or die("Problemas en el SELECT: ".mysql_error());
__________________
¿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: mysql, select
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 12:59.