Foros del Web » Programando para Internet » PHP »

Cómo insertar registros en dos tablas

Estas en el tema de Cómo insertar registros en dos tablas en el foro de PHP en Foros del Web. Hola, nuevamente, compañeros. Tengo una página con un formulario que inserta (correctamente) datos en una tabla de mi bd, pero necesito que me incluya algunos ...
  #1 (permalink)  
Antiguo 17/04/2010, 12:04
Avatar de Lutaj  
Fecha de Ingreso: septiembre-2007
Ubicación: Sevilla
Mensajes: 97
Antigüedad: 16 años, 6 meses
Puntos: 3
Cómo insertar registros en dos tablas

Hola, nuevamente, compañeros.
Tengo una página con un formulario que inserta (correctamente) datos en una tabla de mi bd, pero necesito que me incluya algunos de esos datos en otra tabla de la misma bd. Esta segunda tabla tiene algunos campos iguales que la primera, con los mismos nombres y longitud.
He intentado usar dos insert, pero no me funciona, sólo inserta en la primera de las tablas.
Puedo incluir el código que estoy usando, por si alguien lo requiere.
Gracias.
  #2 (permalink)  
Antiguo 17/04/2010, 12:11
 
Fecha de Ingreso: abril-2010
Mensajes: 115
Antigüedad: 13 años, 11 meses
Puntos: 2
Respuesta: Cómo insertar registros en dos tablas

seria bueno ver el codigo para darme una idea
  #3 (permalink)  
Antiguo 17/04/2010, 13:01
Avatar de Lutaj  
Fecha de Ingreso: septiembre-2007
Ubicación: Sevilla
Mensajes: 97
Antigüedad: 16 años, 6 meses
Puntos: 3
Respuesta: Cómo insertar registros en dos tablas

Éste es el código (simplificando lo no necesario):

<?php
$state = false;
if ($_POST['action'] == "add") {
$conexion = mysql_connect("mysqlhost5", "++++", "+++++");
mysql_select_db("+++++", $conexion);

$que = "INSERT INTO circuito (categoria, carrera, apellidos, nombre, sexo, edad, localidad, club, email, federado, numero, pagado) ";
$que.= "VALUES (
'".$_POST['categoria']."',
'".$_POST['carrera']."',
'".$_POST['apellidos']."',
'".$_POST['nombre']."',
'".$_POST['sexo']."',
'".$_POST['edad']."',
'".$_POST['localidad']."',
'".$_POST['club']."',
'".$_POST['email']."',
'".$_POST['federado']."',
'".$_POST['numero']."',
'".$_POST['pagado']."') ";
$res = mysql_query($que, $conexion) or die(mysql_error());
$state = true;
}
?>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<title>CIRCUITO</title>
</head>
<body>
<form name="frm" method="post" action="" onSubmit ="return Verificar()">

<p><label>&nbsp;&nbsp;Carrera:</label>
<select name="carrera">
<option>carrera1
<option>carrera2
<option>carrera3
</select></p>
<p>Apellidos:
<input name="apellidos" type="text" id="apellidos" />
</p>
<p>Nombre:
<input name="nombre" type="text" id="nombre" />
</p>
<p>Sexo:
<input type="radio" name="sexo" value="H" checked />Hombre
<input type="radio" name="sexo" value="M"/>Mujer
</p>
<p>Fecha de nacimiento:
<input name="edad" type="text" id="edad" />
</p>
<p>Localidad:
<input name="localidad" type="text" id="localidad" />
</p>
<p>Club:
<input name="club" type="text" id="club" />
</p>
<p>Federado en Feder. Riojana Atletismo&nbsp;
<input type="radio" name="federado" value="SÍ" />SÍ
<input type="radio" name="federado" value="NO" checked />NO
</p>
<p>Número:
<input name="numero" type="text" id="numero" />
</p>
<p>Email:
<input name="email" type="text" id="email" />
</p>

<input type="submit" name="Submit" value="Inscribirme" />
<input type="hidden" name="action" value="add" />

</form>

</body>
</html>
  #4 (permalink)  
Antiguo 17/04/2010, 14:25
 
Fecha de Ingreso: abril-2010
Mensajes: 115
Antigüedad: 13 años, 11 meses
Puntos: 2
Respuesta: Cómo insertar registros en dos tablas

bueno... creo ke no incluiste tu segundo insert,
el cual si es "estatico" como dices, deverias de ponerlo abajo del primer insert, algo asi como
Código PHP:
Ver original
  1. $que = "INSERT INTO circuito (categoria, carrera, apellidos, nombre, sexo, edad, localidad, club, email, federado, numero, pagado) ";
  2. $que.= "VALUES (
  3. '".$_POST['categoria']."',
  4. '".$_POST['carrera']."',
  5. '".$_POST['apellidos']."',
  6. '".$_POST['nombre']."',
  7. '".$_POST['sexo']."',
  8. '".$_POST['edad']."',
  9. '".$_POST['localidad']."',
  10. '".$_POST['club']."',
  11. '".$_POST['email']."',
  12. '".$_POST['federado']."',
  13. '".$_POST['numero']."',
  14. '".$_POST['pagado']."') ";
  15.  
  16. $segunda_tabla="inser tinto "la_otra_tabla" values ("tus_datos" )";
  17. $res = mysql_query($que, $conexion) or die(mysql_error());
  18. mysql_query($segunda_tabla,$conexion) or die(mysql_error());// no es necesario asignar el query a otra variable si es ke no las vas necesitar

intenta hacer eso y espero ke funcione
  #5 (permalink)  
Antiguo 18/04/2010, 02:58
Avatar de Lutaj  
Fecha de Ingreso: septiembre-2007
Ubicación: Sevilla
Mensajes: 97
Antigüedad: 16 años, 6 meses
Puntos: 3
Gracias Xfletes, por tu interés. Sigo sin dar en la clave, algo se me escapa. Mira, esto es lo que tengo ahora mismo (siguiendo tus consejos):
<?php
$state = false;
if ($_POST['action'] == "add") {
$conexion = mysql_connect("mysqlhost5", "622862_lutaj", "ltapia");
mysql_select_db("622862_corpor", $conexion);

$que = "INSERT INTO circuito (categoria, carrera, apellidos, nombre, sexo, edad, localidad, club, email, pagado) VALUES (
'".$_POST['categoria']."',
'".$_POST['carrera']."',
'".$_POST['apellidos']."',
'".$_POST['nombre']."',
'".$_POST['sexo']."',
'".$_POST['edad']."',
'".$_POST['localidad']."',
'".$_POST['club']."',
'".$_POST['email']."',
'".$_POST['pagado']."') ";

$que2 = "INSERT INTO prueba (apellidos, nombre, email,) VALUES (
'".$_POST['apellidos']."',
'".$_POST['nombre']."',
'".$_POST['email']."') ";

$res = mysql_query($que, $conexion) or die(mysql_error());
mysql_query($prueba,$conexion) or die(mysql_error());//

$state = true;
}
?>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
etc. etc...

Y me devuelve este mensaje:
Query was empty

Ya me he perdido, no sé por qué me dice que el query está vacío.

Me olvidaba decirte que se realiza insert en la primera tabla (circuito), pero no en la segunda (prueba).
Gracias nuevamente.

Última edición por GatorV; 18/04/2010 a las 20:08

Etiquetas: dos, registros, tablas
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:54.