Foros del Web » Programando para Internet » PHP »

introducir datos en un array

Estas en el tema de introducir datos en un array en el foro de PHP en Foros del Web. Hola, estoy creando gráficos con el Jgraph y para introducir los datos utilizo una consulta a la BBDD y los agrupo por meses. El problema ...
  #1 (permalink)  
Antiguo 21/01/2009, 05:22
 
Fecha de Ingreso: enero-2008
Mensajes: 37
Antigüedad: 16 años, 3 meses
Puntos: 0
introducir datos en un array

Hola, estoy creando gráficos con el Jgraph y para introducir los datos utilizo una consulta a la BBDD y los agrupo por meses.

El problema es el siguiente:
Creo un array para pasar los datos a las coordenadas X e Y de la gráfica. Si un mes no tiene datos, no aparece en la gráfica ya que en la consulta tampoco al no encontrar registros. Pero necesito que en el mes que no haya registros aparezca un 0 para que el mes aparezca en la gráfica.

Como veis aquí está el proceso para crear los valores X e Y
Código PHP:
//creo la consulta
$consulta3 ="SELECT MONTH(FECHA_FIRMA) AS mes, YEAR(FECHA_FIRMA) AS ano, COUNT(ID) AS firmas 
            FROM op_firmas 
            WHERE ANALISTA = '"
.strtoupper($nombrejur)."' AND
            FECHA_FIRMA >= date_sub(CURDATE(),INTERVAL 5 month)
            GROUP BY MONTH(FECHA_FIRMA)
            ORDER BY FECHA_FIRMA"
;
$resultado3=mysql_query($consulta3,$conexion);
if (
$registro3 mysql_fetch_array($resultado3)){
    do {
        
$ydata[] = $registro3['firmas'];
        
$xdata[] = $registro3['mes']."-".$registro3['ano'];
    }while (
$registro3 mysql_fetch_array($resultado3));

Que tengo que poner para que en el caso de que no haya un registro para uno de los meses en el array ydata aparezca un 0 y en el xdata el mes??

Para ser mas gráfico adjunto la gráfica



EL primero es como está actuelmente el codigo de arriba, necesitaría que el resultado fuese como en la segunda imagen.

Alguna idea??

Un saludo.
  #2 (permalink)  
Antiguo 21/01/2009, 05:33
 
Fecha de Ingreso: octubre-2004
Mensajes: 2.627
Antigüedad: 19 años, 6 meses
Puntos: 48
Respuesta: introducir datos en un array

Una opcion es que antes de meter en el array, mires si es el mes que toda, si no lo es meter los elementos vacios. Algo como
Código PHP:
$proximo_mes=calcularPrimerMes();
do {
while (
$registro3['mes']!=$proximo_mes) {
  
$ydata[]=0;
  
$xdata[]=$proximo_mes;
  
$proximo_mes=calcularProximoMes($proximo_mes);
}
        
$ydata[] = $registro3['firmas'];
        
$xdata[] = $registro3['mes']."-".$registro3['ano'];
  
$proximo_mes=calcularProximoMes($proximo_mes);
    }while (
$registro3 mysql_fetch_array($resultado3)); 
  #3 (permalink)  
Antiguo 21/01/2009, 05:38
 
Fecha de Ingreso: abril-2008
Ubicación: Montevideo - Uruguay
Mensajes: 156
Antigüedad: 16 años
Puntos: 5
Respuesta: introducir datos en un array

Hi !

No se si sea la solución correcta :P Pero puedes probar con esto.

Código PHP:
//creo la consulta
$consulta3 ="SELECT MONTH(FECHA_FIRMA) AS mes, YEAR(FECHA_FIRMA) AS ano, COUNT(ID) AS firmas 
            FROM op_firmas 
            WHERE ANALISTA = '"
.strtoupper($nombrejur)."' AND
            FECHA_FIRMA >= date_sub(CURDATE(),INTERVAL 5 month)
            GROUP BY MONTH(FECHA_FIRMA)
            ORDER BY FECHA_FIRMA"
;
$resultado3 mysql_query($consulta3$conexion);

while (
$registro3 mysql_fetch_array($resultado3)) {
    if (
mysql_num_rows($resultado3) > 0) {
        
$ydata[] = $registro3['firmas'];
        
$xdata[] = $registro3['mes']."-".$registro3['ano'];
    }else{
        
$ydata[] = 0;
        
$xdata[] = 0;
    }

Si no te funciona, ya veremos :P

Espero te sea util!
__________________
--
Mi Portfolio Online! Visitalo!
--
  #4 (permalink)  
Antiguo 21/01/2009, 05:45
 
Fecha de Ingreso: octubre-2004
Mensajes: 2.627
Antigüedad: 19 años, 6 meses
Puntos: 48
Respuesta: introducir datos en un array

Otra opcion seria que generases antes los arrays $xdata e $ydata con los valores por defecto, sobre todo si sabes el numero exacto de elementos totales que va a tener. Luego recorres el select y rellenas solo los elementos de las posiciones correspondientes.
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 16:50.