Foros del Web » Programando para Internet » PHP »

Insertar en mas de 2 tablas

Estas en el tema de Insertar en mas de 2 tablas en el foro de PHP en Foros del Web. Señores que tal, esta vez les escribo para presentar una duda... se que han tenido que lidiar con esto alguna vez por eso la pregunta: ...
  #1 (permalink)  
Antiguo 23/08/2008, 16:15
 
Fecha de Ingreso: julio-2008
Ubicación: Trujillo
Mensajes: 58
Antigüedad: 15 años, 8 meses
Puntos: 1
Sonrisa Insertar en mas de 2 tablas

Señores que tal, esta vez les escribo para presentar una duda... se que han tenido que lidiar con esto alguna vez por eso la pregunta:

Tengo el caso de Cliente y sus derivados CLiente Natural y Cliente Juridico.

Ahora cuando yo inserte por ejemplo un cliente natural, se inserte los datos basicos de cliente, y los campos de cliente natural.

Lo mismo si pasara con Cliente Juridico

Ahora como veran mi pregunta es.... como hacer para insertar 2 tablas al mismo tiempo.....

Agradeceria la ayuda que me puedan brindar...

PD. Si esta pregunta no corresponde a este foro me lo hacen saber gracias.
  #2 (permalink)  
Antiguo 23/08/2008, 16:38
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 10 meses
Puntos: 2135
Respuesta: Insertar en mas de 2 tablas

Hola ThePlague,

Para insertar en 2 tablas lo unico que haces es mandar llamar a mysql_query 2 veces con sus respectivas consultas:
Código PHP:
mysql_query"Insert into tabla1 ... " );
mysql_query"Insert into tabla2 ... " ); 
Saludos.
  #3 (permalink)  
Antiguo 26/08/2008, 09:33
 
Fecha de Ingreso: julio-2008
Ubicación: Trujillo
Mensajes: 58
Antigüedad: 15 años, 8 meses
Puntos: 1
Sonrisa Respuesta: Insertar en mas de 2 tablas

Si eso era mi pensamiento pero mi pregunta mas que nada era asi, tengo 2 tablas una llamada CLIENTE y otra llamada CLIENTE NATURAL.

CLiente Natural tiene el id de la tabla cliente, entonces al momento de insertar un nuevo CLIENTE NATURAL tengo que tener el codigo de la tabla CLIENTE, ahi viene mi pregunta, como hacerlo si es que recien estoy insertando tambien el cliente.
Estos son los codigos que estoy haciendo:

La funcion GetSQLValueString esta definida, es una que estoy usando personalmente.

Código PHP:
$insertSQLCliente sprintf("INSERT INTO tb_cliente (ruc, direccion, telefono) VALUES (%s, %s, %s)",
                       
GetSQLValueString($_POST['ruc'], "text"),
                       
GetSQLValueString($_POST['direccion'], "text"),
                       
GetSQLValueString($_POST['telefono'], "text"));

  
mysql_select_db($database_db_conexion$db_conexion);
  
$Result1 mysql_query($insertSQLCliente$db_conexion) or die(mysql_error());
 
  
$insertSQLClienteNatural sprintf("INSERT INTO tb_cliente_natural (apellidos, nombres, dni, email, id_cliente) VALUES (%s, %s, %s, %s, %s)",
                       
GetSQLValueString($_POST['apellidos'], "text"),
                       
GetSQLValueString($_POST['nombres'], "text"),
                       
GetSQLValueString($_POST['dni'], "text"),
                       
GetSQLValueString($_POST['email'], "text"),
                       
GetSQLValueString($_POST['id_cliente'], "text"));

  
mysql_select_db($database_db_conexion$db_conexion);
  
$Result1 mysql_query($insertSQLClienteNatural$db_conexion) or die(mysql_error()); 
Mi problema es de donde obtener el valor id_cliente si recien lo estoy insertando. Agradeceria su ayuda por favor
  #4 (permalink)  
Antiguo 26/08/2008, 09:37
Avatar de foreverOdd  
Fecha de Ingreso: noviembre-2007
Ubicación: Caracas
Mensajes: 489
Antigüedad: 16 años, 4 meses
Puntos: 14
Respuesta: Insertar en mas de 2 tablas

Si es mysql y usas un campo autoincrement para los id entonces te sirve esta funcion

mysql_insert_id()

te da el ultimo id insertado con la conexion actual
__________________
My path is lit by my own fire, I only go where I desire
  #5 (permalink)  
Antiguo 26/08/2008, 09:54
 
Fecha de Ingreso: julio-2008
Ubicación: Trujillo
Mensajes: 58
Antigüedad: 15 años, 8 meses
Puntos: 1
De acuerdo Respuesta: Insertar en mas de 2 tablas

Muy Agradecido, no sabia de la existencia de ese mysql_insert_id:
Pongo el codigo por si alguien necesita saberlo:

Código PHP:
$insertSQLCliente sprintf("INSERT INTO tb_cliente (ruc, direccion, telefono) VALUES (%s, %s, %s)",
                       
GetSQLValueString($_POST['ruc'], "int"),
                       
GetSQLValueString($_POST['direccion'], "text"),
                       
GetSQLValueString($_POST['telefono'], "int"));

  
mysql_select_db($database_db_conexion$db_conexion);
  
$Result1 mysql_query($insertSQLCliente$db_conexion) or die(mysql_error());
  
$idcliente=mysql_insert_id($db_conexion);
 
  
$insertSQLClienteNatural sprintf("INSERT INTO tb_cliente_natural (apellidos, nombres, dni, email, id_cliente) VALUES (%s, %s, %s, %s, %s)",
                       
GetSQLValueString($_POST['apellidos'], "text"),
                       
GetSQLValueString($_POST['nombres'], "text"),
                       
GetSQLValueString($_POST['dni'], "int"),
                       
GetSQLValueString($_POST['email'], "text"),
                       
GetSQLValueString($idcliente"int"));

  
mysql_select_db($database_db_conexion$db_conexion);
  
$Result1 mysql_query($insertSQLClienteNatural$db_conexion) or die(mysql_error()); 
Ojala le sirva a alguien mas. Gracias por la ayuda
  #6 (permalink)  
Antiguo 26/08/2008, 18:02
 
Fecha de Ingreso: julio-2008
Ubicación: Trujillo
Mensajes: 58
Antigüedad: 15 años, 8 meses
Puntos: 1
Sonrisa Respuesta: Insertar en mas de 2 tablas

Vuelvo a escribir porque tengo un pequeño detalle en el codigo que postee anteriormente.
Lo que me pasa es esto:

En el formulario de Registro para un cliente juridico (formulario que usa el codigo de arriba) en el campo RUC ingreso "11111111111" de 11 carcteres, ahora una vez registrado me muestra el siguiente valor: "2147483647" de 10 caracteres no entiendo porque sale eso. He revisado mi codigo y por ningun lado hay alguna formula o ingreso por defecto ese valor "2147483647".

Alguna opinion al respecto, por favor
  #7 (permalink)  
Antiguo 26/08/2008, 19:23
Avatar de Ronruby  
Fecha de Ingreso: julio-2008
Ubicación: 18°30'N, 69°59'W
Mensajes: 4.879
Antigüedad: 15 años, 8 meses
Puntos: 416
Respuesta: Insertar en mas de 2 tablas

El campo INT de MySQL solo acepta desde: -2147483647 hasta 2147483647.

Cambialo a BIGINT.

http://dev.mysql.com/tech-resources/...datatypes.html
  #8 (permalink)  
Antiguo 26/08/2008, 20:39
 
Fecha de Ingreso: julio-2008
Ubicación: Trujillo
Mensajes: 58
Antigüedad: 15 años, 8 meses
Puntos: 1
Respuesta: Insertar en mas de 2 tablas

PLOP!!! tienes toda la razon, se me fue eso... jajajaja... gracias
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 10:05.