Foros del Web » Programando para Internet » PHP »

Enviar arreglo php y buscarlo en mysql

Estas en el tema de Enviar arreglo php y buscarlo en mysql en el foro de PHP en Foros del Web. Hola que tal.. Ojala alguien pueda ayudarme con esto... Estoy enviando un arreglo desde php a otro form para que me haga busquedas en mysql, ...
  #1 (permalink)  
Antiguo 17/10/2013, 17:33
 
Fecha de Ingreso: mayo-2013
Mensajes: 16
Antigüedad: 10 años, 11 meses
Puntos: 0
Enviar arreglo php y buscarlo en mysql

Hola que tal..
Ojala alguien pueda ayudarme con esto...
Estoy enviando un arreglo desde php a otro form para que me haga busquedas en mysql, pero cada posición del arreglo tomo esos datos para que se genere una consulta sql y me imprima la info, hasta el momento lo que he logrado es que haga la búsqueda pero me genere una búsqueda por cada posición del arreglo y no por el arreglo completo..
mi arreglo es asi:
per[][nom]
per[][ap]
per[][am]

Gracias por cualquier ayuda....

Código PHP:


foreach ($_POST['per'] as $item) {
  echo $item['nom'];
  echo $item['ap'];
  echo $item['am'];
  
 
$busca="SELECT *  FROM tabla WHERE (nombre like '%$item[nom]%') and (paterno like '%$item[ap]%') and (materno like '%$item[am]%') ORDER BY paterno,materno,nombre";
 
         $result=mysql_query($busca,$conexion) ;
         $filas=mysql_num_rows($result);
      
   while ($row = mysql_fetch_array($result))
            {
                  $nombre =utf8_encode($row["nombre"]);
               $paterno =utf8_encode($row["paterno"]);
               $materno =utf8_encode($row["materno"]);
               
            }      
 ?>                  
      
     
        <td width="20%" ><h6><?php echo $nombre?> </h6></td>
        <td width="22%"><h6><?php echo $paterno?>  </h6></td>
        <td width="22%"><h6><?php echo $materno?></h6></td>
       <td width="22%"><h6><?php echo $zona?></h6></td>
   <?php  
}      
 
 }
  #2 (permalink)  
Antiguo 17/10/2013, 23:31
 
Fecha de Ingreso: enero-2012
Ubicación: México
Mensajes: 27
Antigüedad: 12 años, 3 meses
Puntos: 0
Respuesta: Enviar arreglo php y buscarlo en mysql

Creo que es porque tienes tu búsqueda dentro del foreach, guarda los datos del arreglo en variables y después haces tu consulta con esas variables. Saludos!!
  #3 (permalink)  
Antiguo 18/10/2013, 06:13
Avatar de gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 16 años, 4 meses
Puntos: 2658
Respuesta: Enviar arreglo php y buscarlo en mysql

Las variables de PHP no existen para MySQL. Son sistemas independientes comunicándose en base a una determinada librería, pero lo que está recibiendo MySQL es una cadena de texto que contiene una sentencia a ejecutar.
El resto es invisible para el DBMS.

Además, no existen los arrays en MySQL...

Pero yendo al caso, la consulta resulta muy ineficiente para la base, y no es posible, en el contexto que lo propones, recuperar una lista de registros en base a N valores de un array. Para hacerlo con algo como lo que planteas habría que implementarlo en un stored procedure, mediante una lógica algo compleja.
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)

Última edición por gnzsoloyo; 18/10/2013 a las 06:26
  #4 (permalink)  
Antiguo 18/10/2013, 09:50
Avatar de Cuervoo  
Fecha de Ingreso: octubre-2013
Mensajes: 165
Antigüedad: 10 años, 6 meses
Puntos: 43
Respuesta: Enviar arreglo php y buscarlo en mysql

Me parece que lo encaraste un poco torcido al asunto, capaz se puede hacer de otra forma. Mostra como estás tratando el formulario de donde recibe ese arreglo y por ahi se puede hacer distinto.
  #5 (permalink)  
Antiguo 18/10/2013, 12:50
 
Fecha de Ingreso: mayo-2013
Mensajes: 16
Antigüedad: 10 años, 11 meses
Puntos: 0
Respuesta: Enviar arreglo php y buscarlo en mysql

Hola
gracias por responder...
Lo que estoy tratando de hacer es enviar una lista de nombres con un array y hacer una consulta para obtener todos esos datos de una sola vez en la base de datos..
Cambie un poco el codigo por esto:

Código PHP:
Ver original
  1. foreach ($_POST['per'] as $item) {
  2.  
  3.  echo $item['nom']; echo $item['ap']; echo $item['am'];
  4.  
  5. $select = "SELECT  FROM tabla";
  6.  
  7. $where = "";
  8.  
  9.  
  10.  
  11.     if ($where == "") {
  12.          $where = " WHERE (nombre like '%$item[nom]%') and (paterno like '%$item[ap]%') and (materno like '%$item[am]%')";
  13.     }
  14.      else {
  15.          $where = " OR (nombre like '%$item[nom]%') and (paterno like '%$item[ap]%') and (materno like '%$item[am]%')";
  16.     }
  17.  
  18.  
  19. $order = "ORDER BY paterno,materno,nombre";
  20.  
  21.             $busca = $select.$where.$order;
  22.             $result=mysql_query($busca,$conexion) ;
  #6 (permalink)  
Antiguo 18/10/2013, 15:46
 
Fecha de Ingreso: enero-2012
Ubicación: México
Mensajes: 27
Antigüedad: 12 años, 3 meses
Puntos: 0
Respuesta: Enviar arreglo php y buscarlo en mysql

Mira como tenias tu código al principio guardas tus valores del arreglo en variables para poder cerrar tu foreach y después ya haces tu consulta, algo asi:


Cita:
$c=0;
foreach ($_POST['per'] as $item) {
echo "$item<br>";
$val[$c]=$item;
$c=$c+1;

}


$busca="SELECT * FROM tabla WHERE nombre='$val[0]' and paterno='$val[1]' and materno='$val[2]' ORDER BY paterno,materno,nombre";

$result=mysql_query($busca,$conexion);


while ($row=mysql_fetch_assoc($result))
{
$nombre =utf8_encode($row["nombre"]);
$paterno =utf8_encode($row["paterno"]);
$materno =utf8_encode($row["materno"]);

}
Pruebalo y nos avisas, saludos!
  #7 (permalink)  
Antiguo 18/10/2013, 18:10
 
Fecha de Ingreso: mayo-2013
Mensajes: 16
Antigüedad: 10 años, 11 meses
Puntos: 0
Respuesta: Enviar arreglo php y buscarlo en mysql

Hola
Por fin lo solucione, gracias a los que me ayudaron..
Lo que pasa es que estaba enviando mal en arreglo desde que se creaba..

Etiquetas: arreglo, mysql, 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 07:07.