Foros del Web » Programando para Internet » PHP »

error con la memoria (Problema solucionado..!!)

Estas en el tema de error con la memoria (Problema solucionado..!!) en el foro de PHP en Foros del Web. me podrian echar una mamito en esto: Código PHP: <?php session_start (); require( 'conexion.php' ); $nro_control = $_POST [ 'nro_control' ]; $query = "SELECT s.precio_servicio, s.descr_servicio, r.edo_recibo, d.serial_cartu FROM servicios.servicio s, servicios.detall_recib_cartu d, servicios.recibo r where d.nro_control=1115 AND r.nro_control=d.nro_control AND s.cod_servicio=d.cod_servicio;" ; ...
  #1 (permalink)  
Antiguo 20/05/2010, 09:32
 
Fecha de Ingreso: octubre-2009
Mensajes: 23
Antigüedad: 14 años, 6 meses
Puntos: 0
Pregunta error con la memoria (Problema solucionado..!!)

me podrian echar una mamito en esto:

Código PHP:
<?php
session_start
();
require(
'conexion.php');
$nro_control=$_POST['nro_control'];
$query="SELECT s.precio_servicio, s.descr_servicio, r.edo_recibo, d.serial_cartu FROM servicios.servicio s, servicios.detall_recib_cartu d, servicios.recibo r where d.nro_control=1115 AND r.nro_control=d.nro_control AND s.cod_servicio=d.cod_servicio;";

    
$resul=$conex->query($query);
    if(
$resul->num_rows<1)
    {
        echo
"['101']";
        exit;
    }
    else
    {
        
$datos=$resul->fetch_assoc();
        if(
$datos['edo_recibo']=='cancelado'){
                echo
"['911']";
              } else {
                  
$i=0;
                  while(
$datos)
                    {
                    
$descr_articulo=$datos['descr_servicio'];
                    
$nserial=$datos['serial_cartu'];
                    
$precio_servicio=$datos['precio_servicio'];
                    
$data[$i] = array("nserial" => "$nserial""descr_articulo" => "$descr_articulo","precio_servicio"=>"$precio_servicio");
                    
$i++;
                 }
                echo 
json_encode($data);
              }
    }
?>
me genera esta respuesta:

Código HTML:
<br />
<b>Fatal error</b>:  Allowed memory size of 104857600 bytes exhausted (tried to allocate 51 bytes) in <b>C:\AppServ\www\tecnico\consultarRetiroCartucho.php</b> on line <b>25</b><br /> 
serviria acotar que la cantidad de registros de consulto no es mayor a 6

asi que me parece ilogico que este agotada la memoria puesto tiene 100 mb asignados

de antemano gracias

Última edición por isidro_01; 20/05/2010 a las 09:40 Razón: problema solucionado
  #2 (permalink)  
Antiguo 20/05/2010, 09:41
Avatar de darkasecas  
Fecha de Ingreso: marzo-2005
Ubicación: SantaCata, NL, Mexico
Mensajes: 1.553
Antigüedad: 19 años, 1 mes
Puntos: 77
Respuesta: error con la memoria (Problema solucionado..!!)

Tienes un ciclo infinito, asignas un valor a $datos, y luego haces un ciclo que se realizara mientras $datos tenga algun valor, pero dentro del ciclo nunca cambias el valor de $datos, por lo que nunca saldra de este.
  #3 (permalink)  
Antiguo 20/05/2010, 09:49
 
Fecha de Ingreso: octubre-2009
Mensajes: 23
Antigüedad: 14 años, 6 meses
Puntos: 0
Respuesta: error con la memoria (Problema solucionado..!!)

<?php
session_start();
require('conexion.php');
$nro_control=$_POST['nro_control'];
$query="SELECT s.precio_servicio, s.descr_servicio, r.edo_recibo, d.serial_cartu FROM servicios.servicio s, servicios.detall_recib_cartu d, servicios.recibo r where d.nro_control=1115 AND r.nro_control=d.nro_control AND s.cod_servicio=d.cod_servicio;";

$resul=$conex->query($query);
if($resul->num_rows<1)
{
echo"['101']";
exit;
}
else
{
$i=0;
while($datos=$resul->fetch_assoc())
{if($datos['edo_recibo']=='cancelado'){
echo"['911']";
} else {

$descr_articulo=$datos['descr_servicio'];
$nserial=$datos['serial_cartu'];
$precio_servicio=$datos['precio_servicio'];
$data[$i] = array("nserial" => "$nserial", "descr_articulo" => "$descr_articulo","precio_servicio"=>"$precio_serv icio");
$i++;
}
echo json_encode($data);
}
}
?>

Etiquetas: memoria, solucionado
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 21:01.