Foros del Web » Programando para Internet » PHP »

Insertar array asociativo con php y mysql ?????

Estas en el tema de Insertar array asociativo con php y mysql ????? en el foro de PHP en Foros del Web. Hola, estoy haciendo un formulario web, a través de este mando los datos introducidos a un archivo php, donde los almaceno en un array asociativa, ...
  #1 (permalink)  
Antiguo 01/03/2012, 05:40
 
Fecha de Ingreso: octubre-2009
Mensajes: 13
Antigüedad: 15 años, 1 mes
Puntos: 0
Insertar array asociativo con php y mysql ?????

Hola, estoy haciendo un formulario web, a través de este mando los datos introducidos a un archivo php, donde los almaceno en un array asociativa, con su clave - valor.

Ahora esos datos, los tengo que insertar en la tabla correspondiente de la base de datos. Casualmente las claves del array coinciden con los campos de la tabla, asi que he pensado hacer un método genérico que reciba como argumento un array asociativo y la tabla donde se van a insertar dichos valores.

La setencia sql, sería de este modo :

insert into `tabla` (campo1, campo2, campo3)
values ('valor1', 'valor2', 'valor3');

Asi que me he puesto manos a la obra y he hecho esto

Código PHP:
echo ("insert into `global`.`usuario` (" );
foreach (
$vector as $key => $value) {
            echo (
$key " , ");
        }
echo (
") values (");

foreach (
$vector as $key => $value) {
            echo (
"'" $value "' , ");
        }
echo (
");"); 
Tengo 2 problemas:

1 la setencia sql obtenida sería insert into `tabla` (campo1 , campo2 , campo3 , )
values ('valor1', 'valor2', 'valor3' , ); Y claro las ultimas , sobran
2 como meto eso en una variable $sql_sentencia, para hacer uso de la funcion:

mysql_query($sql_sentencia,$conectar);

Salu2 y gracias de antemano
  #2 (permalink)  
Antiguo 01/03/2012, 07:05
Avatar de repara2  
Fecha de Ingreso: septiembre-2010
Ubicación: München
Mensajes: 2.445
Antigüedad: 14 años, 2 meses
Puntos: 331
Respuesta: Insertar array asociativo con php y mysql ?????

Código PHP:
Ver original
  1. <?php
  2.  
  3. function creaSQL($datos)
  4. {
  5.     $sql = "INSERT INTO db.table (";
  6.     foreach($datos as $key => $value)
  7.     {
  8.         $sql .="'$key',";
  9.     }
  10.     $sql = substr($sql, 0, -1);
  11.     $sql .=") VALUES (";
  12.     foreach($datos as $key => $value)
  13.     {
  14.         $sql .="'$value',";
  15.     }
  16.     $sql = substr($sql, 0, -1);
  17.     $sql .= ");";
  18.    
  19.     return $sql;
  20. }
  21.  
  22. $datos = array('campo1' => 'valor1', 'campo2' => 'valor2');
  23. $sql = creaSQL($datos);
  24. echo $sql;
  25. //Conectar
  26. //Hacer query con $sql como parámetro
  27.  
  28. ?>
__________________
Fere libenter homines, id quod volunt, credunt.
  #3 (permalink)  
Antiguo 01/03/2012, 07:10
Avatar de DooBie  
Fecha de Ingreso: septiembre-2004
Mensajes: 1.101
Antigüedad: 20 años, 2 meses
Puntos: 71
Respuesta: Insertar array asociativo con php y mysql ?????

Haz las cosas bien, si tienes la función implode(); no hace falta que uses tanto foreach ni substr, ni nada por el estilo.
Mira la web de php.net y busca la función implode(); en los ejemplos, creo que el primero, sale un ejemplo de lo que buscas, solo tienes que adaptarlo.
  #4 (permalink)  
Antiguo 01/03/2012, 13:12
 
Fecha de Ingreso: octubre-2009
Mensajes: 13
Antigüedad: 15 años, 1 mes
Puntos: 0
Respuesta: Insertar array asociativo con php y mysql ?????

Muchas gracias, me ha funcionado perfectamente con la función. Respecto a implode() , lo investigaré, que por lo que he visto en la wen de php.net te facilita mucho las cosas y si se puedo ahorrar codido pues mucho mejor

Salu2

Etiquetas: asociativo, formulario, mysql, sql, tabla, variables, usuarios
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 09:20.