Foros del Web » Programando para Internet » PHP »

Listar articulos relacionados por tema desde BBDD MySql

Estas en el tema de Listar articulos relacionados por tema desde BBDD MySql en el foro de PHP en Foros del Web. Hola estoy queriendo hacer una lista de articulos relacionados por temas/categorias (algo como lo que piden aqui http://www.forosdelweb.com/f86/elimi...-mysql-666963/ ), ya traje lo que necesito de ...
  #1 (permalink)  
Antiguo 16/04/2010, 14:32
Usuario no validado
 
Fecha de Ingreso: marzo-2007
Mensajes: 238
Antigüedad: 17 años, 1 mes
Puntos: 5
Listar articulos relacionados por tema desde BBDD MySql

Hola estoy queriendo hacer una lista de articulos relacionados por temas/categorias (algo como lo que piden aqui http://www.forosdelweb.com/f86/elimi...-mysql-666963/), ya traje lo que necesito de la BBDD:

Código PHP:
$sql mysql_query("SELECT name_cat, name_item FROM tbl_items, tbl_cat WHERE id_num = 149 AND tbl_cat.id_cat = tbl_items.id_cat "); 
Y me trae esto:
Código:
   1. Opinion | Item 1
   2. Opinion | Item 2
   3. Opinion | Item 3
   4. Notas Nacionales | Item 1
   5. Notas Nacionales | Item 2
   6. Notas Nacionales | Item 3
   7. Notas Nacionales | Item 4
   8. Notas Nacionales | Item 5
  9. Entrevistas | Item 1
  10. Entrevistas | Item 2
  11. Entrevistas | Item 3
en Php estoy:
Código PHP:
while ($row mysql_fetch_row($sql)) {
    
$growthList .= '<li>'.$row[0].' | '.$row[1].'</li>';
}
echo 
"<ol style='text-align:left;'>".$growthList."</ol>"
Pero como lo quiero mostrar es asi:
Código:
   1. Opinion | Item 1,  Item 2, Item 3
   2. Notas Nacionales | Item 1, Item 2, Item 3, Item 4, Item 5
  3. Entrevistas | Item 1, Item 2, Item 3
Que me hace falta? no hayo con que instrucciones o com desplegarlo asi
  #2 (permalink)  
Antiguo 16/04/2010, 15:12
Avatar de santris  
Fecha de Ingreso: agosto-2009
Ubicación: Sant Feliu de Llobregat
Mensajes: 955
Antigüedad: 14 años, 8 meses
Puntos: 66
Respuesta: Listar articulos relacionados por tema desde BBDD MySql

Puedes probar a meter los resultados de cada paso del while en un array y luego mostrarlos como quieras.

no se, algo como:

Código PHP:
$items = array();
while(
$rows mysql_fetch_assoc($rs))
{
$items[]=$rows;

__________________
Tu álbum de cromos online!!
  #3 (permalink)  
Antiguo 16/04/2010, 15:14
 
Fecha de Ingreso: abril-2010
Ubicación: Colombia
Mensajes: 229
Antigüedad: 14 años
Puntos: 2
Respuesta: Listar articulos relacionados por tema desde BBDD MySql

Intenta este codigo

<?php
$datos = "";
while ($row = mysql_fetch_row($sql)) {


if($datos != $row[0]){
$datos = $row[0];
$growthList1 .= $row[0];
}

$growthList .= $growthList1.' | '.$row[1];
}
echo "<ol style='text-align:left;'>".$growthList."</ol>";


?>


La idea es controlar que en el arreglo $row[0] no se repita y si es asi no lo pinte.

Espero que te ayude........
  #4 (permalink)  
Antiguo 19/04/2010, 12:36
Usuario no validado
 
Fecha de Ingreso: marzo-2007
Mensajes: 238
Antigüedad: 17 años, 1 mes
Puntos: 5
Respuesta: Listar articulos relacionados por tema desde BBDD MySql

pepeluis1 no me salio como me dijiste aunque se me hacia algo interesante por lo simplificado, al final hice algo como recomienda santris de guardar en un arrray:
Código PHP:
$title '';
$tema0;
$arr = array();
while (
$row mysql_fetch_row($sql)) {
    
$arr[$tema][0] = $row[0];
    
$arr[$tema][1] = $row[1];
    
$tema ++;
}

echo 
"<ol style='text-align:left;'>\n";
foreach(
$arr as $v1) {
    if (
$title!=$v1[0]) 
    {
    print 
"<li><b>$v1[0]/ </b>";
        foreach (
$arr as $v2) {
        if(
$v2[0]==$v1[0])
        print 
" $v2[1]/";
        }
    print 
"</li>\n";
    }
    
$title $v1[0];
}
echo 
"</ol>"
...funcionando! GRACIAS

Etiquetas: articulos, bbdd, listar, mysql, relacionados, tema
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:19.