Foros del Web » Programando para Internet » PHP »

Insertar un array sin bucle

Estas en el tema de Insertar un array sin bucle en el foro de PHP en Foros del Web. Buenas existen alguna manera de insertar un array sin realizar un bucle del tipo for, foreach ?? digo seria como para optimizar no realizar tantas ...
  #1 (permalink)  
Antiguo 05/02/2009, 15:13
 
Fecha de Ingreso: diciembre-2008
Mensajes: 190
Antigüedad: 15 años, 3 meses
Puntos: 6
Insertar un array sin bucle

Buenas existen alguna manera de insertar un array sin realizar un bucle del tipo for, foreach ?? digo seria como para optimizar no realizar tantas consultas...se que para borrar se puede con un IN..
muchas gracias-.
  #2 (permalink)  
Antiguo 06/02/2009, 04:36
Colaborador
 
Fecha de Ingreso: marzo-2008
Ubicación: Cáceres
Mensajes: 3.735
Antigüedad: 16 años
Puntos: 300
Respuesta: Insertar un array sin bucle

turfeano,
yo lo que suelo hacer es crear con programación una sola cadena para hacer una inserción múltiple, utilizando for o foreach, claro (el bucle es necesario para recorrer el array); pero teniendo cuidado de que no sea demasiado larga. Luego en MySQL sólo hago una inserción.
Piensa que esto:
INSERT INTO nombretabla (campoimpares, campopares) VALUES (1,2), (3,4), (5,6)
ingresaría cada número en su lugar.
Se trata de formar con programación esa cadena y sólo cuando esté completa hacer la inserción, una sola inserción y no una en cada iteración. ¿Te refieres a eso?
  #3 (permalink)  
Antiguo 06/02/2009, 10:27
 
Fecha de Ingreso: diciembre-2008
Mensajes: 190
Antigüedad: 15 años, 3 meses
Puntos: 6
Respuesta: Insertar un array sin bucle

Gracias por la ayuda, me diste la idea.. dejo el codigo para quien necesite..
el tema es que necesitaba tb escapar las variables con mysql_real_escape_string ... bueno en fin, n ejemplo para insertar varios dominios a un sitio...
Con esto evito hacer un INSERT dentro del for y realizar consultas de mas...


$dominios = array();

Código PHP:
$dominios $_REQUEST['dominio']; //cargo los dominos

for ($i=0;$i<=count($dominios)-1;$i++){ // menos  1 porque el for hace 0,1,2 y el count es 1,2
 
$dominios[$i] = mysql_real_escape_string($dominios[$i]); //escpapo las variables
  
$sQuery="INSERT INTO dominios (sitioid,dominio) VALUES";
   
     
$sQuery .= "('".$sitioid."','".$dominios[$j]."'),";
     }
     
$sQuery substr ($sQuery0, -1); //saco ultima coma
     
$sQuery .= ";"//inserto punto y coma para realizar bien la consulta
  
    
$reg=mysql_query($sQuery,$db);

if (
$reg) echo "inserto dominio"
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 06:34.