Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Array y consulta en php

Estas en el tema de Array y consulta en php en el foro de PHP en Foros del Web. Buenas a todos necesito ayuda con un array en php En base de datos tengo guardado en una tabla un campo tipo varchar donde guardo ...
  #1 (permalink)  
Antiguo 24/08/2015, 16:46
Avatar de lisllo_1  
Fecha de Ingreso: mayo-2015
Mensajes: 12
Antigüedad: 4 años, 8 meses
Puntos: 0
Array y consulta en php

Buenas a todos necesito ayuda con un array en php
En base de datos tengo guardado en una tabla un campo tipo varchar donde guardo varios codigos separados por comas
ejemplo
Codigo Grupo
1 1,3
2 2,4

Cada codigo que esta guardado en grupo corresponde al nombre del grupo

cuando realizo la consulta para que me traiga los nombres solo me trae el nombre que esta en la primera posicion y no el que esta despues de la coma.

esto es lo que he hecho:
Código PHP:
$array = array();
    while(
$filas=mysql_fetch_array($rGuia)){
       
$array[] = $filas[0];
    }    
    
$separado_por_comas implode(","$array);
    
print_r ($array); 
y esta es mi consulta
Código PHP:
$sqlquery "SELECT  p.Nombre AS Programa,  gr.Nombre AS Grupo, g.Nombre AS Codigo_guia, CONCAT(d.Nombre,' ',d.Apellidos), ga.Grupo, g.Codigo,h.Nombre AS Horario,ga.Fecha_inicio,ga.Fecha_fin,ga.Num_ini,ga.Num_fin
              FROM  grupos gr, programas p ,guias_activas ga, guias g, docentes d,horarios h
              WHERE p.Codigo = gr.Programa 
              AND gr.Codigo = ga.Grupo  
              AND ga.Grupo IN($separado_por_comas)              
              AND ga.Codigo_Guia = g.Codigo
              AND g.Programa = p.Codigo
              AND d.Codigo = ga.Docente
              AND h.Codigo = ga.horario
              AND ga.Estado = 1"

la consulta me trae la informacion correcta pero en el campo nombre solo me trae uno solo nombre donde en verdad hay dos?
por favor si alguien me puede ayudar
  #2 (permalink)  
Antiguo 25/08/2015, 10:08
 
Fecha de Ingreso: agosto-2010
Ubicación: santiago, CHILE
Mensajes: 557
Antigüedad: 9 años, 5 meses
Puntos: 9
Respuesta: Array y consulta en php

y si cambias SELECT SUBSTRING(p.Nombre,1) AS Programa,

encuentro raro si es un varchar te de problema con eso, pero prueba directamente en la BD si con substring te funciona.
  #3 (permalink)  
Antiguo 25/08/2015, 11:59
Avatar de lisllo_1  
Fecha de Ingreso: mayo-2015
Mensajes: 12
Antigüedad: 4 años, 8 meses
Puntos: 0
Respuesta: Array y consulta en php

bueno aqui les dejo como lo hice por si alguien lo llega a necesitar


Código PHP:
#aqui una consulta
    //se crea el array
    
$arrays = array();
    while(
$filas=mysql_fetch_array($rGuia)){
        
$arrays[] = $filas[0];       
    }   
    
    
//saco el numero de elementos
     
$longitud count($arrays);
 
    
//Recorro todos los elementos
    
for($i=0$i<$longitud$i++){
      
//saco el valor de cada elemento y lo coloco en la consulta   
      
$sqlquery "SELECT  p.Nombre AS Programa,  (SELECT group_concat(Nombre) FROM grupos  WHERE Codigo IN (".$arrays[$i].")), g.Nombre AS Codigo_guia, CONCAT(d.Nombre,' ',d.Apellidos), ga.Grupo, g.Codigo,h.Nombre AS Horario,ga.Fecha_inicio,ga.Fecha_fin,ga.Num_ini,ga.Num_fin
              FROM  grupos gr, programas p ,guias_activas ga, guias g, docentes d,horarios h
              WHERE p.Codigo = gr.Programa 
              AND gr.Codigo = ga.Grupo                            
              AND ga.Codigo_Guia = g.Codigo
              AND ga.Grupo IN("
.$arrays[$i].")
              AND g.Programa = p.Codigo
              AND d.Codigo = ga.Docente
              AND h.Codigo = ga.horario
              AND ga.Estado = 1"
;
             
       
$rGuias mysql_query($sqlquery) or die(mysql_error());
      
//los muestro
      
while($row mysql_fetch_array($rGuias)){             
          echo 
'<tr> 
          <td class="border">'
.$row[0].'</td>        
          <td class="border"NOWRAP>'
.$row[1].'</td>
          <td class="border">'
.$row[2].'</td>
          <td class="border"NOWRAP>'
.$row[3].'</td>
          <td class="border"NOWRAP>'
.$row[6].'</td>
          <td class="border">'
.$row[7].'</td>
          <td class="border">'
.$row[8].'</td>
          <td class="border">'
.$row[9].'</td> 
          <td class="border">'
.$row[10].'</td>         
          </tr>'
;
          
          
$Acum=$Acum $row[9];
          
$Acumu=$Acumu $row[10];
          
$Total=    $Acum $Acumu;    
        
        } 
    } 
y todo dentro del for

Etiquetas: fecha, select, sql, 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 05:25.