Foros del Web » Programando para Internet » PHP »

Guardar en Array el resultado de varias consultas

Estas en el tema de Guardar en Array el resultado de varias consultas en el foro de PHP en Foros del Web. Hola.. buen dia, estuve revisando foros anteriores para encontrar solucion a mi ejercicio, pero aun no he podido solucionarlo. Tengo un array con varios codigos ...
  #1 (permalink)  
Antiguo 19/10/2010, 16:59
 
Fecha de Ingreso: octubre-2010
Mensajes: 3
Antigüedad: 13 años, 6 meses
Puntos: 0
Guardar en Array el resultado de varias consultas

Hola.. buen dia, estuve revisando foros anteriores para encontrar solucion a mi ejercicio, pero aun no he podido solucionarlo.
Tengo un array con varios codigos que se refieren a unos sitios, por cada sitio debo hacer una consulta (esta me retorna un array), pero necesito guardar cada resultado, ya que al terminar de recorrer los codigos de los sitios debo visualizar todo lo encontrado... estoy utilizando esto:

$consulta = "SELECT oc.ids as ids, oc.numero as num ..... FROM orden_compra_, orden_detalle .... WHERE ....... AND ..... ";

$cantidad= sizeof($_SESSION["varios_sitios"]);

for ($i=0;$i < $cantidad ;$i++)
{
if (($_SESSION["varios_sitios"][$i]) != 0)
{
$consulta .= " AND sitio = ".$_SESSION["varios_sitios"][$i];
}

$consulta .= " ORDER BY oc.oficina_fk, numero";
$result = mysql_query($consulta, $conexion);
$resultado = array_merge($resultado,$result);[/COLOR]
$i++;
}


el array_merge , lo vi buscando como podría guardar un array en otro.. pero no esta funcionando, ya que debo guardar los resultados que tengo con el nuevo.. alguien tiene alguna observación...

Les agradezco su aporte .. :D
  #2 (permalink)  
Antiguo 20/10/2010, 01:21
Avatar de repara2  
Fecha de Ingreso: septiembre-2010
Ubicación: München
Mensajes: 2.445
Antigüedad: 13 años, 7 meses
Puntos: 331
Respuesta: Guardar en Array el resultado de varias consultas

Antes de continuar comprueba que la variable $resultado en este punto no tiene valor o es un array vacío:

Código PHP:
    $resultado array_merge($resultado,$result); 
$resultado es el merge de nada + $result (suponiendo que hayas posteado el código completo).

Por otra parte, incrementas dos veces el valor de $i, una en el for y otra forzada por tí (tal vez es lo que quieres):

Código PHP:
$resultado array_merge($resultado,$result);
$i++; //Este incremento ya se hace en el for, necesitas otro? 
Puedes intentar debugear así:

Código PHP:
error_reporting(E_ALL);
ini_set("display_errors",1);

$arVariosSitios = array(2,3,4,5,66,76,43,23,49,90,87);

$consulta "SELECT oc.ids as ids, oc.numero as num ..... FROM orden_compra_, orden_detalle .... WHERE ....... AND ..... ";

for (
$i=0;$i sizeof($arVariosSitios) ;$i++)
{
    if ((
$arVariosSitios[$i]))
    {
        
$consulta .= " AND sitio = ".$arVariosSitios[$i];
    }

    
$consulta .= " ORDER BY oc.oficina_fk, numero";
    
$result mysql_query($consulta$conexion);
    
$resultado array_merge($resultado,$result);
    
//$i++;

Espero que sirva, saludos
  #3 (permalink)  
Antiguo 20/10/2010, 07:51
 
Fecha de Ingreso: octubre-2010
Mensajes: 3
Antigüedad: 13 años, 6 meses
Puntos: 0
Respuesta: Guardar en Array el resultado de varias consultas

hola, como estas? te agradezco el haberme contestado.. si tenias razón estaba haciendo mal varias cosas... hasta hace poco empece con esto de la programacion... y pensaba q los resultados de las consultas quedaban almacenadas en un array (:P), fijate que me dijeron que no era necesario guardar todas las consultas, que podía colocar en el WHERE de la consluta un... IN al array de los sitios y que con eso me tomaba todos los codigos de los sitios del usuario... mas o menos asi:

$consulta = "SELECT oc.ids as ids, oc.numero as num ..... FROM orden_compra_, orden_detalle .... WHERE ....... AND ..... ";
if (in_array(0,$_SESSION["varias_cons_usu"])){continue;}

$consulta .= " AND construccion_fk IN ". (implode(";",$_SESSION["varias_cons_usu"]));

$consulta .= " ORDER BY oc.oficina_fk, numero";

$resultado = mysql_query($consulta, $conexion);

pero aun asi, la consulta no esta funcionando... luego de la consulta hay un while ($registro = mysql_fetch_array($resultado)) y me imagino que no funciona porque la consulta no esta arrojando la respuesta correctamente...
:S
  #4 (permalink)  
Antiguo 20/10/2010, 08:57
 
Fecha de Ingreso: octubre-2010
Mensajes: 3
Antigüedad: 13 años, 6 meses
Puntos: 0
Respuesta: Guardar en Array el resultado de varias consultas

HOLA... YA SOLUCIONE EL INCONVENIENTE...
LA CONSULTA TENIA PENDIENTE LOS PARÉNTESIS DEL IMPLODE...
IN (". implode(",",$_SESSION["varias_cons_usu"]).")";


MIL GRACIAS POR TODO.. SEGUIRÉ MOLESTANDO SI TENGO ALGUNA OTRA INQUIETUD... O SI PUEDO COLABORAR EN ALGO... :D

Etiquetas: resultados
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 19:28.