Foros del Web » Programando para Internet » PHP »

Agrupar resultados de la base de datos

Estas en el tema de Agrupar resultados de la base de datos en el foro de PHP en Foros del Web. Buenas gente del foro... Mediante una consulta simple estoy trayendo información desde una base de datos (noticias: titulo, fecha, cuerpo), y en una pagina hago ...
  #1 (permalink)  
Antiguo 22/04/2008, 16:42
Avatar de [NiRVaNa]  
Fecha de Ingreso: abril-2004
Ubicación: Someplace In The Middle Of Nowhere!
Mensajes: 325
Antigüedad: 20 años
Puntos: 6
Pregunta Agrupar resultados de la base de datos

Buenas gente del foro...

Mediante una consulta simple estoy trayendo información desde una base de datos (noticias: titulo, fecha, cuerpo), y en una pagina hago que me filtre las noticias por mes, es decir, las noticias que se escribieron en marzo, apareceran cuando hago click en el link de marzo, y asi sucesivamente.

Y ahora necesito algo mas (aqui es donde necesito ayuda), luego de que se filtra por mes, necesito que aparesca el dia (en numero) y al lado los titulos de las noticias de ese dia.

El problema surge cuando hay mas de una noticia en un dia, ya que queda algo asi:
Cita:
14
Titulo 1

14
Titulo 2

14
Titulo 3
y la idea es que quede asi:
Cita:
14
Titulo 1
Titulo 2
Titulo 3
Como podria hacer eso?

Les dejo el codigo que estoy utilizando:
Código PHP:
$sql "SELECT titulo, subtitulo, idnoticia, date_part('day', fecins) ";
$sql .= "FROM noticias ";
$sql .= "WHERE date_part('month', fecins) = ".$_GET['go'];
$sql .= "AND (opcion = 'PC') order by idnoticia";
$result = @pg_query($dbconn$sql);
        if (!
$result) {
            echo 
"<span style=\"color: green;\">Ocurrio un error al recuperar la informaci&oacute;n de la base de datos!</span>";
        } else {
            while (
$row pg_fetch_row($result)) {
                echo 
"<h1>".$row[3]."</h1>\n";
                echo 
"<p><strong>".$row[0]."</strong></p>\n<blockquote>".$row[1]."</blockquote>\n<p></p>\n";
            }
        } 
Quiero hacer algo parecido a esto: http://www.creativosargentinos.org/2...th=3&year=2007

Última edición por [NiRVaNa]; 22/04/2008 a las 16:48
  #2 (permalink)  
Antiguo 22/04/2008, 16:49
Avatar de kaninox  
Fecha de Ingreso: septiembre-2005
Ubicación: In my House
Mensajes: 3.597
Antigüedad: 18 años, 7 meses
Puntos: 49
Re: Agrupar resultados de la base de datos

eso es por que en tu while estas trayendo el dia y el titulo entonces tira todo lo que debes hacer es solo poner en el bucle while los titulos y mostrar el dia con una variable sin while me explico????
__________________
Gokuh Salvo al mundo. PUNTO!!!!
  #3 (permalink)  
Antiguo 22/04/2008, 17:36
(Desactivado)
 
Fecha de Ingreso: diciembre-2006
Mensajes: 529
Antigüedad: 17 años, 4 meses
Puntos: 11
Re: Agrupar resultados de la base de datos

Tienes que aprender a hacer uso de "banderas" que dirijan el tránsito... algo así:


Código PHP:
$sql "SELECT titulo, subtitulo, idnoticia, date_part('day', fecins) ";
$sql .= "FROM noticias ";
$sql .= "WHERE date_part('month', fecins) = ".$_GET['go'];
$sql .= "AND (opcion = 'PC') order by idnoticia";
$result = @pg_query($dbconn$sql);
        if (!
$result) {
            echo 
"<span style=\"color: green;\">Ocurrio un error al recuperar la informaci&oacute;n de la base de datos!</span>";
        } else {
           
$dia "";
            while (
$row pg_fetch_row($result)) {
 
               if (
$row[3] != $dia) {
                
$dia =  $row[3];        
                echo 
"<h1>".$row[3]."</h1>\n";
               }
                echo 
"<p><strong>".$row[0]."</strong></p>\n<blockquote>".$row[1]."</blockquote>\n<p></p>\n";
            }
        } 
$dia es mi bandera.

Saludos
  #4 (permalink)  
Antiguo 22/04/2008, 17:41
(Desactivado)
 
Fecha de Ingreso: diciembre-2006
Mensajes: 529
Antigüedad: 17 años, 4 meses
Puntos: 11
Re: Agrupar resultados de la base de datos

Me faltó algo en el código anterior, yA LO corregí...

Saludos
  #5 (permalink)  
Antiguo 22/04/2008, 17:53
 
Fecha de Ingreso: noviembre-2002
Mensajes: 746
Antigüedad: 21 años, 5 meses
Puntos: 6
Re: Agrupar resultados de la base de datos

bueno y si no quieres tocar na y añadir algo hazzz

$primer_resultado=1;
if ($primer_resultado>1){echo $fila['titulo'];}else{echo $dia.'<br>'.$fila['titulo'];}
$primer_resultado=$primer_resultado + 1;
  #6 (permalink)  
Antiguo 23/04/2008, 08:40
Avatar de [NiRVaNa]  
Fecha de Ingreso: abril-2004
Ubicación: Someplace In The Middle Of Nowhere!
Mensajes: 325
Antigüedad: 20 años
Puntos: 6
Re: Agrupar resultados de la base de datos

Gracias, se me habia ocurrido hacer algo como lo que aporto usermax, pero pense que se me iba a complicar mucho el panorama, ahora veo que no es tan asi.

Muchas gracias.
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 05:43.