Foros del Web » Programando para Internet » PHP »

Actualizar/insertar clave ajena desde formulario php.

Estas en el tema de Actualizar/insertar clave ajena desde formulario php. en el foro de PHP en Foros del Web. Buenas gentecilla!! Necesito de vuestra sabiduria porque ya estoy mal de la cabeza, pffff. Tengo este formulario hecho en dreamweaver: *Tipo: lista/menú que carga los ...
  #1 (permalink)  
Antiguo 18/01/2008, 05:31
 
Fecha de Ingreso: enero-2008
Mensajes: 9
Antigüedad: 16 años, 3 meses
Puntos: 0
Actualizar/insertar clave ajena desde formulario php.

Buenas gentecilla!!
Necesito de vuestra sabiduria porque ya estoy mal de la cabeza, pffff.

Tengo este formulario hecho en dreamweaver:
*Tipo: lista/menú que carga los datos de tipoequipo.tipoequipo
*Marca: lista/menú que carga los datos de marcas.marca
*Modelo: campo de texto que introduzco y se envia correctamente a equipo.modelo
*Nº de serie: igual que el campo modelo
*Observaciones: igual que el campo modelo

Os comento la estructura de las 3 tablas en phpMyAdmin:
-->1ª. equipos(id_equipo, id_marca, id_tipo, modelo, numeroserie, observaciones)
-->2ª. marcas(id_marca, marca)
-->3ª. tipoequipo(id_tipo, tipoequipo)

En el formulario elijo una marca, un tipo, e introduzco el resto, se me manda bien y se graba bien a medias, porque no se como actualizar la tabla equipos para que en las claves ajenas id_marca y id_tipo me aparezca el código de esa marca y de ese tipo que acabo de elegir.

La linea nueva en equipos se me queda así:
Id_equipo=454
Id_marca=0
Id_tipo=0
Modelo=p5ld2
Numeroserie=5d5d6s3cddd
Observaciones=lo que sea

En el value de lista/menu de marca y de tipo, pongo su id del recordset que carga de marcas y de tiposequipos el combo, no se si estará bien o que o si me faltarán más cosa, pero no me lo escribe. He probado con hacer un "if ((isset($_POST["MM_insert"])) && ($_POST["MM_insert"] == "form1")) {" pero me da error, supongo por ser un campo que no introduzco manualmente o elijo en el formulario.



¿Me podeis ayudar? . Será una tontá,porque no he visto de momento un tema así, pero no me sale...
Gracias de antemano.
  #2 (permalink)  
Antiguo 18/01/2008, 06:03
Avatar de jcxnet  
Fecha de Ingreso: octubre-2005
Ubicación: Perú
Mensajes: 784
Antigüedad: 18 años, 6 meses
Puntos: 56
Re: Actualizar/insertar clave ajena desde formulario php.

Me parece que necesitas una lista enlazada, o me equivoco ? si estoy en lo cierto dale una mirada a estos enlaces a ver si te pueden ayudar ;)
http://www.obispot.com/labs/codigo/listas-ajax-json/
http://www.tallerwebmaster.com/Tutor...adas-c-77.html
__________________
►I'm a devil on the run ♂
Jcxnet.com
*Keep It Simple **
  #3 (permalink)  
Antiguo 18/01/2008, 11:44
 
Fecha de Ingreso: enero-2008
Mensajes: 9
Antigüedad: 16 años, 3 meses
Puntos: 0
Re: Actualizar/insertar clave ajena desde formulario php.

Muchas gracias por los enlaces!!!; son super claros y muy útiles, más tarde queria hacer eso. Pero el caso es que no me soluciona lo de ahora.
Lo vuelvo a explicar:
Al elegir una marca y un tipoequipo, quiero que los id's que identifican esos campos marca y tipoequipo se manden a la tabla equipos que tiene esos dos campos (id_marca e id_tipoequipo) que son clave ajena de las tablas marcas y tipoequipo.
Ejm:
TABLA MARCAS
registro 1.-
id=1
marca=hp
registro 2.-
id=2
marca=canon
.....Y más registros

TABLA TIPOEQUIPO
registro 1.-
id=20
tipoequipo=impresora
registro 2.-
id=21
tipoequipo=portatil
.....Y más registros

En el formulario elijo impresora como tipo(que tiene el id 20) y de la marca hp (que es 1) y el resto de los campos modelo, etc... da igual. Bien. El registro que se me añade en la tabla equipos seria:
id_equipo= 45
id_tipo= 0 (tenia que ser 20)
id_marca=0 (tenia que ser 1)
modelo= lo que haya introducido en el formulario
numero de serie= lo que haya introducido en el formulario
observaciones= lo que haya introducido en el formulario


Espero haberme explicado mejor y que me podais guiar un poquejo.... 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 21:19.