Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Consulta para mostrar noticias por categoria

Estas en el tema de Consulta para mostrar noticias por categoria en el foro de PHP en Foros del Web. Que tal tengo un problema que no puedo resolver hasta ahora, Tengo una base de datos donde tengo dos tablas, una de categoria y otra ...
  #1 (permalink)  
Antiguo 19/02/2013, 10:03
 
Fecha de Ingreso: marzo-2010
Mensajes: 25
Antigüedad: 14 años, 7 meses
Puntos: 2
Consulta para mostrar noticias por categoria

Que tal tengo un problema que no puedo resolver hasta ahora, Tengo una base de datos donde tengo dos tablas, una de categoria y otra de noticias.

Obviamente estas tablas estan enlazadas es decir en las noticias hay un id foraneo para ponerle la categoria a cada noticia.

Lo que deseo hacer es lo siguiente.

Necesito mostrar las noticias del dia actual, lo que es sencillo con un SELECT, pero al mostralas necesito que se agrupen en su CATEGORIA correspondiente. Tendia que listar todas las noticias que tenga en la base de datos que correspondan a la fecha actual..

Esta es mi consulta para que vean mis tablas...

SELECT noticia.id_noticia, noticia.titulo, noticia.fecha, noticia.cat_noticia, categoria.id_categoria, categoria.nombre FROM categoria INNER JOIN noticia ON categoria.id_categoria =noticia.cat_noticia WHERE noticia.fecha_noticia = '".$fecha_actual


Un ejemplo de como se deberia ver..

categoria AUTOS
- Noticia 1
- Noticia 2
- Noticia 3

categoria CELULARES
- Noticia 1

categoria DEPORTES
- Noticia 1
- Noticia 2

Como veran cada categoria puede tener diferente numero de noticias... La cantidad de categorias tambien puede variar...

Espero me ayuden...
  #2 (permalink)  
Antiguo 19/02/2013, 10:10
Avatar de dashtrash
Colaborador
 
Fecha de Ingreso: abril-2007
Ubicación: Ni en Sevilla,ni en Sanlúcar..qué más da..
Mensajes: 927
Antigüedad: 17 años, 7 meses
Puntos: 270
Respuesta: Consulta para mostrar noticias por categoria

Selecciona todas las noticias del día, ordenadas por categoría.
Al leer las rows desde PHP, cuando veas un cambio de categoría (la fila n tiene una categoria distinta a la fila (n-1)), escribe la cabecera de la nueva categoria.
  #3 (permalink)  
Antiguo 19/02/2013, 10:15
 
Fecha de Ingreso: marzo-2010
Mensajes: 25
Antigüedad: 14 años, 7 meses
Puntos: 2
Respuesta: Consulta para mostrar noticias por categoria

Cita:
Iniciado por dashtrash Ver Mensaje
Selecciona todas las noticias del día, ordenadas por categoría.
Al leer las rows desde PHP, cuando veas un cambio de categoría (la fila n tiene una categoria distinta a la fila (n-1)), escribe la cabecera de la nueva categoria.
..pero como lo mostraria en codigo :S
  #4 (permalink)  
Antiguo 19/02/2013, 10:26
Avatar de dashtrash
Colaborador
 
Fecha de Ingreso: abril-2007
Ubicación: Ni en Sevilla,ni en Sanlúcar..qué más da..
Mensajes: 927
Antigüedad: 17 años, 7 meses
Puntos: 270
Respuesta: Consulta para mostrar noticias por categoria

Te lo estoy diciendo...Si lo que quieres es que te escriba directamente el código...más o menos es algo así...

Código PHP:
Ver original
  1. $res=mysql_query("SELECT.........");
  2.    $curCat=-1;
  3.    while($arr=mysql_fetch_assoc($res))
  4.    {
  5.           if($curCat!=$arr["categoria"])
  6.           {
  7.                  // La query devolvera un ID de categoria, pero lo que quieres imprimir es el NOMBRE
  8.                  // El array $nombreCategoria tiene como clave el id, como valor, el nombre.
  9.                  echo "<b>".$nombreCategoria[$arr['categoria']]."</b><br>"
  10.                  $curCat=$arr["categoria"];
  11.           }
  12.           // codigo para pintar una noticia.
  13.     }
  #5 (permalink)  
Antiguo 19/02/2013, 11:12
 
Fecha de Ingreso: marzo-2010
Mensajes: 25
Antigüedad: 14 años, 7 meses
Puntos: 2
Respuesta: Consulta para mostrar noticias por categoria

Excelente ... me sircio.. Mil gracias

Etiquetas: select, tabla
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 22:31.