Foros del Web » Programando para Internet » PHP »

Almacenar varios registros en una BD MySql con PHP

Estas en el tema de Almacenar varios registros en una BD MySql con PHP en el foro de PHP en Foros del Web. Hola a todos en el foro, soy nuevo aqui y voy a lanzar mi primera pregunta, el problema es el siguiente: Lo que sucede es ...
  #1 (permalink)  
Antiguo 13/02/2013, 12:00
 
Fecha de Ingreso: febrero-2013
Mensajes: 3
Antigüedad: 11 años, 2 meses
Puntos: 0
Almacenar varios registros en una BD MySql con PHP

Hola a todos en el foro, soy nuevo aqui y voy a lanzar mi primera pregunta, el problema es el siguiente:

Lo que sucede es que tengo una pagina en la cual genero unos inputs type text de manera dinamica con javascript y de esto no hay ningun problema, mi duda es al momento de enviar estos campos a un archivo PHP donde se procesan, como podria hacer para guardarlos en la BD, ya que podria ser solo un solo registro o hasta N cantidad de registros, es decir, tengo que agregar productos pero no se como procesar las variables que se envian al php para almacenar varios al mismo tiempo en mi BD
  #2 (permalink)  
Antiguo 13/02/2013, 12:11
 
Fecha de Ingreso: diciembre-2010
Ubicación: Rosario, Santa Fe
Mensajes: 326
Antigüedad: 13 años, 4 meses
Puntos: 13
Respuesta: Almacenar varios registros en una BD MySql con PHP

Necesitas crear una tabla que tenga la clave primaria de de la tabla donde guardas el resto de la información y el valor de cada campo, es decir:

Tabla 1: id, campo1, campo2, campo3
Tabla 2: tabla1_id, valor

Entonces en Tabla 2 generas N registros donde tabla1_id es el valor del grupo al que pertenecen y valor el contenido de cada input.

Si nos dices en más detalle cuales son los campos necesarios puedo dar de forma más precisa como quedan las tablas.
  #3 (permalink)  
Antiguo 13/02/2013, 12:23
Avatar de Ilidam  
Fecha de Ingreso: julio-2009
Ubicación: Veracruz
Mensajes: 108
Antigüedad: 14 años, 9 meses
Puntos: 0
Respuesta: Almacenar varios registros en una BD MySql con PHP

Si ya tienes tu formulario en donde vas agregando tus registros supongo que tiene tus input asi...
para que puedas hacer eso podria ser asi
ejemplo.php
<form action="recibe.php">
<input name="dato1[]" type="text" />
<input name="dato2[]" type="text" />
</form>

para almacenar multiples registros los recibes
recibe.php
$uno=$_POST['dato'];// ojo aki solo pones el nombre del imput sin el array []
$dos=$_POST['dato2'];

y ya para almacenarlos a la base lo haces asi

for($i = 0; $i<count ($uno); $i++) {
$sql=mysql_query("Insert Into tabla(uno,dos) values('$uno[$i]','($dos[$i])')");
echo"registro exitoso";
}


saludos y suerte
  #4 (permalink)  
Antiguo 13/02/2013, 12:27
 
Fecha de Ingreso: febrero-2013
Mensajes: 3
Antigüedad: 11 años, 2 meses
Puntos: 0
Respuesta: Almacenar varios registros en una BD MySql con PHP

Hola areslepra gracias por la respuesta tan rapida, pero creo que no me he explicado bien del todo, no tengo problemas con las tablas de la BD mi problema es que no se coo hacer para procesar todas las variables que me envia mi formulario al archivo php y despues como almacenarlas en la BD es decir:
tengo los siguientes campos

<input type="button" value=" + " onclick='agregar()'>
<input name="prod" type='text' style="width:100%">
<input name="tipo" type='text' style="width:100%">
<input type="radio" name="trimestre" value="I">
<input type="radio" name="trimestre" value="II">
<input type="radio" name="trimestre" value="III">
<input type="radio" name="trimestre" value="IV">

El boton de "agregar" me genera tantos inputs sean necesarios para que el usuario ingrese los productos que el requiera en esto no hay probblema, el problema es que no he encontrado la forma de como procesarlos para guardarlos en la BD ya que minimo puede ser 1 registro y hasta N cantidad
  #5 (permalink)  
Antiguo 13/02/2013, 12:32
Avatar de Ilidam  
Fecha de Ingreso: julio-2009
Ubicación: Veracruz
Mensajes: 108
Antigüedad: 14 años, 9 meses
Puntos: 0
Respuesta: Almacenar varios registros en una BD MySql con PHP

verifica el msj que publique te puede servir porque lo que quieres hacer lo debes hacer con arrays yo tambien tuve ese problema alguna vez jeje
  #6 (permalink)  
Antiguo 13/02/2013, 12:35
 
Fecha de Ingreso: diciembre-2010
Ubicación: Rosario, Santa Fe
Mensajes: 326
Antigüedad: 13 años, 4 meses
Puntos: 13
Respuesta: Almacenar varios registros en una BD MySql con PHP

Simplemente tenés que hacer que los campos se llamen por ejemplo: prod[0], prod[1], .... y lo mismo para todos, siendo por ejemplo:

<input name="prod[0]" type='text' style="width:100%">
<input name="tipo[0]" type='text' style="width:100%">
<input type="radio" name="trimestre[0]" value="I">
<input type="radio" name="trimestre[0]" value="II">
<input type="radio" name="trimestre[0]" value="III">
<input type="radio" name="trimestre[0]" value="IV">

<input name="prod[1]" type='text' style="width:100%">
<input name="tipo[1]" type='text' style="width:100%">
<input type="radio" name="trimestre[1]" value="I">
<input type="radio" name="trimestre[1]" value="II">
<input type="radio" name="trimestre[1]" value="III">
<input type="radio" name="trimestre[1]" value="IV">

Luego desde PHP accedes como $_POST['prod'][0], $_POST['prod'][1], etc. Ya que $_POST['prod'] será un arreglo al igual que el resto. Por lo cual podés poner algo así:

Código PHP:
<?php
foreach (array_keys($_POST['prod']) as $i)
{
     
// Acá usamos los campos.
     
echo $_POST['prod][$i];
     echo $_POST['
tipo][$i];
     echo 
$_POST[trimestre][$i];
}
  #7 (permalink)  
Antiguo 13/02/2013, 12:39
 
Fecha de Ingreso: febrero-2013
Mensajes: 3
Antigüedad: 11 años, 2 meses
Puntos: 0
Respuesta: Almacenar varios registros en una BD MySql con PHP

areslepra y Ilidam gracias por sus prontas respuestas creo que las soluciones que me mencionan son similares por los arrays hare la implementacion de las soluciones que me brindan

Gracias

Etiquetas: mysql, php+basedatos
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 03:53.