Foros del Web » Programando para Internet » PHP »

Duda arrays como parametros en funcion al insertar en mysql

Estas en el tema de Duda arrays como parametros en funcion al insertar en mysql en el foro de PHP en Foros del Web. Hola tengo la siguiente duda. tengo varios arrays. y necesito hacer inserciones de los valores que contienen los arrays a tablas en una base de ...
  #1 (permalink)  
Antiguo 11/11/2011, 12:04
 
Fecha de Ingreso: septiembre-2010
Mensajes: 28
Antigüedad: 13 años, 8 meses
Puntos: 0
Duda arrays como parametros en funcion al insertar en mysql

Hola tengo la siguiente duda. tengo varios arrays. y necesito hacer inserciones de los valores que contienen los arrays a tablas en una base de datos.

Código PHP:
// estos datos ingresarian a una tabla   tb_servicios
$servicios['agua'] =100;
$servicios['luz'] =  120);
$servicios['cloaca'] = 40;
// estos datos ingresarian a una tabla  tb_extras
$extra['telefono'] = 60;
$extra['gas'] = 10;
$extra['cable'] = 25;
$extra['internet'] = 14
ahora llamo a la funcion
Código PHP:

insertarMysql
($nombredelarray,nombre de la tabla); 
la funcion sería
Código PHP:
function insertarMysql($nameArray,$nameTable){
    
//peticion
            
$peticion=mysql_query("INSERT INTO $nameTable  VALUES (NULL, 
//NULL por que el primer valor en la tabla es auto ingremental 
//,aqui me pierdo como extraigo los valores del array para 
//pasarlos como valores en la peticion, y pueda ser compatible
// con los demas arrays q entren a esta funcion. 

)"
);



Espero se entienda lo que necesito ... gracias anticipadas :).
  #2 (permalink)  
Antiguo 11/11/2011, 12:12
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Duda arrays como parametros en funcion al insertar en mysql

Podrías iterar el array con foreach(), la verdad no entiendo tu complicación.

Es curioso que estés trabajando primariamente con arrays y no sepas trabajar con ellos.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 11/11/2011, 12:54
 
Fecha de Ingreso: noviembre-2011
Mensajes: 7
Antigüedad: 12 años, 5 meses
Puntos: 1
Respuesta: Duda arrays como parametros en funcion al insertar en mysql

Muy importante, asumo que 'agua' 'luz' 'cloaca' ... y todas las demas claves
en tu arreglo son campos de la tabla y tienen ese mismo nombre en tu base de datos.
Si no es asi una simple modificacion en una de ellas podria ayudar

<?php
function insertarMysql($nameArray,$nameTable){
$nameString="id"; //pongo id pero debes poner el nombre del campo autoincremental de la tabla
$valueString="NULL";
foreach($nameArray as $key => $value){
$nameString.=$key;
$valueString.=$value;
}

$peticion=mysql_query("INSERT INTO $tableName($nameString) VALUES ($valueString)");
return $peticion;
}
?>

Espero te sirva de algo, no estoy seguro si me faltan quotes, pero en ese caso es mas sencillo de arreglar
  #4 (permalink)  
Antiguo 12/11/2011, 07:41
 
Fecha de Ingreso: septiembre-2010
Mensajes: 28
Antigüedad: 13 años, 8 meses
Puntos: 0
Respuesta: Duda arrays como parametros en funcion al insertar en mysql

Ola pateketrueke no sabia como regorrer el foreach yo pensaba hacerlo en la zona de values de la peticion sql. y como que no tenia idea como iria la sintaxis. :).

Gracias 0skr me sirve mucho tu post. y si los campos de la tabla llevan esos nombres, solo faltaria en
Código PHP:
VALUES ($valueString
meterle alguna funcion que los separe y les ponga una coma porque sino estaría entrando
Código PHP:
NULLNONOSINONOSINONO 
todo junto.
gracias a hora le buscaré alguna funcion que los vaya separando.
  #5 (permalink)  
Antiguo 12/11/2011, 09:00
 
Fecha de Ingreso: septiembre-2010
Mensajes: 28
Antigüedad: 13 años, 8 meses
Puntos: 0
Respuesta: Duda arrays como parametros en funcion al insertar en mysql

RESUELTO :)
aqui pongo el codigo por si esque alguién se topa con el mismo problema. obvie el forecha porque era hacer un paso y regresar a lo mismo en vano.

Código PHP:
//funcion Inserta en la base de datos se le pasa el Nombre de la tabla y el array
function insertarMysql($nameArray,$nameTable){
            include_once(
'cnx/cnx.php');
            
//Seleccionamos la BD
            
mysql_select_db('inmobiliaria',$cnx);
            
//peticion concateno el nombre de la tabla con ID porque asi se llama mi clave primaria
            
$nameString="ID"
            
$nameString.=$nameTable
            
// a los valores del array les pongo comillas y los separo por coma.
            
            
$valores =  implode("', '",array_map('mysql_escape_string'$nameArray));
           
            
// obvio los nombres de mis campos nunca tuve problemas :) solo ingreso los valores. a $valores les pongo comillas porque el implode de arriba me deja sin comillas de unicio al primer valor del array y sin comillas de cierre al ultimo.
            
$peticion=mysql_query("INSERT INTO $nameTable  VALUES ( NULL, '$valores')");

            return 
$peticion;
            } 
espero si mi duda es duda de otros, pueda ser aclarada. Gracias

Etiquetas: arrays, funcion, mysql, parametros, 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 17:20.