Foros del Web » Programando para Internet » PHP »

Mostrar datos separados por coma

Estas en el tema de Mostrar datos separados por coma en el foro de PHP en Foros del Web. Tengo dos tablas en mi base de datos: usuario, promociones, ; en una almaceno el nombre de cada usuario, y en promociones esta el numero ...
  #1 (permalink)  
Antiguo 28/11/2009, 14:35
Avatar de alexmo  
Fecha de Ingreso: mayo-2005
Ubicación: México
Mensajes: 120
Antigüedad: 18 años, 11 meses
Puntos: 0
Mostrar datos separados por coma

Tengo dos tablas en mi base de datos: usuario, promociones, ; en una almaceno el nombre de cada usuario, y en promociones esta el numero de promociones a la que cada usuario se registra:

Por ejemplo:

TABLA USUARIOS

id_usuario | nombre
1 | Fabio
2 | Daniel
3 | Maria

TABLA PROMOCIONES

id | id_promocion | id_usuario
1 | 2 | 1
2 | 6 | 2
3 | 4 | 2
4 | 3 | 3
5 | 6 | 1

Lo que necesito es que al mostrar la lista de usuarios me aparezca en cada fila el nombre del usuario y las promociones a las que esta inscrito separadas por coma, así:

Nombre | Promociones
Fabio | 2, 6
Daniel | 6, 4
Maria | 3

¿Cómo podría hacerlo?

Mil gracias de antemano por su ayuda.
  #2 (permalink)  
Antiguo 28/11/2009, 14:59
Avatar de urgido  
Fecha de Ingreso: febrero-2005
Mensajes: 2.351
Antigüedad: 19 años, 2 meses
Puntos: 25
Respuesta: Mostrar datos separados por coma

tienes algún código realizado al menos para sacar los valores?
__________________
Hospedaje Web al mejor costo!
  #3 (permalink)  
Antiguo 28/11/2009, 15:12
Avatar de alexmo  
Fecha de Ingreso: mayo-2005
Ubicación: México
Mensajes: 120
Antigüedad: 18 años, 11 meses
Puntos: 0
Respuesta: Mostrar datos separados por coma

Claro, hago la consulta a la base de datos, la unión entre ambas tablas y genero el listado, pero en la columna de promociones solo me aparece la primera y necesito que me salgan todas las que pertenezcan a cada usuario separadas por coma.

El código de la consulta es:

Código PHP:
$sql=mysql_query("SELECT * FROM clientes LEFT JOIN promociones ON clientes.id_usuario = promociones.id_usuario",$con);

//muestra los datos consultados
echo "<p>Nombre - Promociones</p> \n";
while(
$row mysql_fetch_array($sql)){
    echo 
"<p>".$row['nombre']." - ".$row['id_promocion']."</p> \n";

  #4 (permalink)  
Antiguo 28/11/2009, 15:25
Avatar de urgido  
Fecha de Ingreso: febrero-2005
Mensajes: 2.351
Antigüedad: 19 años, 2 meses
Puntos: 25
Respuesta: Mostrar datos separados por coma

Código PHP:
Ver original
  1. <?
  2. $sql=mysql_query("SELECT * FROM clientes LEFT JOIN promociones ON clientes.id_usuario = promociones.id_usuario",$con);
  3.  
  4. //muestra los datos consultados
  5. echo "<p>Nombre - Promociones</p> \n";
  6. while($row = mysql_fetch_array($sql)){
  7.     $valores[]=$row['id_promocion'];
  8.     foreach ($valores as &$valor) {
  9.         if((end($valores))!=$valor){
  10.          $totales[]=$valor.", ";
  11.         }else{
  12.          $totales[]=$valor;
  13.         }
  14.     }
  15.    
  16.    foreach ($totales as &$final) {
  17.     // tomamos los totales
  18.    }
  19. }
  20.  
  21. echo "<p>".$row['nombre']." - ".$final."</p> \n";
  22. ?>


checate si te funciona lo hice aquí...

que hace el code? pues le pone , excepto al último valor ó eso intente. Slaudos
__________________
Hospedaje Web al mejor costo!
  #5 (permalink)  
Antiguo 28/11/2009, 16:20
Avatar de alexmo  
Fecha de Ingreso: mayo-2005
Ubicación: México
Mensajes: 120
Antigüedad: 18 años, 11 meses
Puntos: 0
Respuesta: Mostrar datos separados por coma

Gracias urgido
Pero la lista me queda con registros independientes por fila asi:

Nombre | Promociones
Fabio | 2
Fabio | 6
Daniel | 6
Daniel | 4
Maria | 3

No sé si depronto la consulta SELECT esté mal hecha.
  #6 (permalink)  
Antiguo 28/11/2009, 16:25
Avatar de urgido  
Fecha de Ingreso: febrero-2005
Mensajes: 2.351
Antigüedad: 19 años, 2 meses
Puntos: 25
Respuesta: Mostrar datos separados por coma

mete el ultimo hecho al while :)
__________________
Hospedaje Web al mejor costo!
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 20:16.