Foros del Web » Programando para Internet » PHP »

llenar formulario en base a select para actualizar

Estas en el tema de llenar formulario en base a select para actualizar en el foro de PHP en Foros del Web. Hola: Tengo este formulario (modificar_bioderm.php) Código HTML: <form action= "update_bioderm.php" method= "post" enctype= "multipart/form-data" name= "bioderm" id= "bioderm" > Código PHP: <? include ( "config.php" ); ...
  #1 (permalink)  
Antiguo 30/09/2006, 10:39
 
Fecha de Ingreso: noviembre-2002
Ubicación: Colombia
Mensajes: 278
Antigüedad: 22 años
Puntos: 0
llenar formulario en base a select para actualizar

Hola:

Tengo este formulario (modificar_bioderm.php)

Código HTML:
<form action="update_bioderm.php" method="post" enctype="multipart/form-data" name="bioderm" id="bioderm"> 
Código PHP:
<?
include ("config.php");

//Creamos la sentencia SQL y la ejecutamos
$sSQL="Select ref From bioderm Order By ref ASC";
$result=mysql_query($sSQL);

echo 
'<select name="ref">';
echo 
"<option value=\"\">-- Seleccione un producto --</option>\n";

//Mostramos los registros en forma de men&uacute; desplegable
while ($row=mysql_fetch_array($result))
{echo 
'<option>'.$row["ref"];}
mysql_free_result($result)
?>
Código HTML:
<input type="submit" name="Submit" value="Actualizar" /> 

El form me muestra perfectamente los productos en base a su referencia (ref). El problema es que al hacer clik en Actualizar, pasa a el otro form que deberia estar lleno con los datos del producto, en base a la referencia (ref) seleccionada en el select, pero el form no aparece lleno con los datos.

Este es el codigo del form que aparece vacio (update_bioderm.php)
Código PHP:
<? 
include ("config.php"); 

if (isset(
$_GET['ref'])){ 
$sSQL="SELECT * FROM bioderm WHERE ref='".$_GET['ref']."'"
$result=mysql_query($sSQL); 
$row=mysql_fetch_array($result); 

?>
Código HTML:
<form action="change_bioderm.php" method="post" enctype="multipart/form-data" name="bioderm" id="bioderm">

<input name="nombre" type="text" id="nombre" value="<? echo $row['nombre']; ?>" size="35" />

<input name="ref" type="text" id="ref" value="<? echo $row['ref']; ?>" size="5" />

<input type="submit" name="Submit" value="Actualizar" />

</form> 

Se que alguna vez me funciono algo similar pero perdi el codigo y ahora no doy con el funcionamiento. Gracias por colaborar!
  #2 (permalink)  
Antiguo 30/09/2006, 10:45
Avatar de caricatos
Moderador
 
Fecha de Ingreso: abril-2002
Ubicación: Torremolinos (Málaga)
Mensajes: 19.607
Antigüedad: 22 años, 7 meses
Puntos: 1284
Hola:

A simple vista envías el formulario con el método post y lo recibes con get...

Saludos
__________________
Por favor:
No hagan preguntas de temas de foros en mensajes privados... no las respondo
  #3 (permalink)  
Antiguo 30/09/2006, 11:09
Avatar de skatomundo  
Fecha de Ingreso: junio-2002
Ubicación: Santiago - CL
Mensajes: 2.532
Antigüedad: 22 años, 5 meses
Puntos: 125
DEberia ser:

Código PHP:
if (isset($_POST['ref'])){ 
$sSQL="SELECT * FROM bioderm WHERE ref='".$_POST['ref']."'"
$result=mysql_query($sSQL); 
$row=mysql_fetch_array($result); 

  #4 (permalink)  
Antiguo 30/09/2006, 12:27
 
Fecha de Ingreso: noviembre-2002
Ubicación: Colombia
Mensajes: 278
Antigüedad: 22 años
Puntos: 0
claro... vaya error! pruebo ahora mismo. gracias
  #5 (permalink)  
Antiguo 30/09/2006, 12:30
 
Fecha de Ingreso: noviembre-2002
Ubicación: Colombia
Mensajes: 278
Antigüedad: 22 años
Puntos: 0
tenias razon. muchas gracias!
  #6 (permalink)  
Antiguo 30/09/2006, 14:05
 
Fecha de Ingreso: septiembre-2006
Mensajes: 196
Antigüedad: 18 años, 2 meses
Puntos: 0
hola iarrieta, yo queria hacer los mismo suerte k pusiste este tema. cree tus paginas y cambie los ref->id_sala, nombre->nombre_sala y bioderm->sala (= mi conexion) y el resultado de las textbox me aparece en blanco. tienes alguna idea de k toy haciendo mal?

me di cuenta de q el form es diferente pq yo no nunca he trabajado con get ni post y ahora se divide con en un form de varias partes si note bien con enctype="multipart/form-data" para mandar y recibir los datos me imagino, nose si por ahi puede estar mi error
  #7 (permalink)  
Antiguo 30/09/2006, 16:16
 
Fecha de Ingreso: noviembre-2002
Ubicación: Colombia
Mensajes: 278
Antigüedad: 22 años
Puntos: 0
pues tendrias que colocar tu codigo completo para compararlo, porque no entiendo muy bien a que te refieres.
  #8 (permalink)  
Antiguo 30/09/2006, 16:40
 
Fecha de Ingreso: septiembre-2006
Mensajes: 196
Antigüedad: 18 años, 2 meses
Puntos: 0
lo mire muchas veces y lo veo = de todas maneras te lo mando, ojala encuentres lo que se me escapa:

esta es modificar_sala.php
Código PHP:
<form action="update_sala.php" method="post" enctype="multipart/form-data" name="sala" id="sala">
<? 
include ("conexion.php"); 

//Creamos la sentencia SQL y la ejecutamos 
$sSQL="Select id_sala From sala Order By id_sala ASC"
$result=mysql_query($sSQL); 

echo 
'<select name="id_sala">'
echo 
"<option value=\"\">-- Seleccione un producto --</option>\n"

//Mostramos los registros en forma de men&uacute; desplegable 
while ($row=mysql_fetch_array($result)) 
{echo 
'<option>'.$row["id_sala"];} 
mysql_free_result($result
?> 
<input type="submit" name="Submit" value="Actualizar" />

</form>
y esta es update_sala.php

Código PHP:
<?  
include ("conexion.php");  

if (isset(
$_POST['id_sala'])){ 
$sSQL="SELECT * FROM sala WHERE id_sala='".$_POST['id_sala']."'"
$result=mysql_query($sSQL); 
$row=mysql_fetch_array($result); 
}  
 
?> 

<form action="change_sala.php" method="post" enctype="multipart/form-data" name="sala" id="sala">

<input name="nombre_sala" type="text" id="nombre_sala" value="<? echo $row['nombre_sala']; ?>" size="35" />

<input name="id_sala" type="text" id="id_sala" value="<? echo $row['id_sala']; ?>" size="5" />
    
<input type="submit" name="Submit" value="Actualizar" />

</form>
Código:
CREATE TABLE sala (
   ID_SALA int(11) DEFAULT '0' NOT NULL,
   NOMBRE_SALA varchar(50),
   CAPACIDAD_SALA int(11),
   PRIMARY KEY (ID_SALA),
);

INSERT INTO sala VALUES ( '1', 'Sala Chica', '20');
INSERT INTO sala VALUES ( '2', 'Laboratorio', 'clases', '50');
INSERT INTO sala VALUES ( '3', 'Sala Musica', '10');
Saludos

Última edición por gazuzax; 30/09/2006 a las 16:47
  #9 (permalink)  
Antiguo 30/09/2006, 19:11
 
Fecha de Ingreso: noviembre-2002
Ubicación: Colombia
Mensajes: 278
Antigüedad: 22 años
Puntos: 0
Bueno, lo unico que veo quizas pueda ser la falla es que en mi caso, el campo "ref" no es el principal de la bese de datos, es decir tu "id_sala"

Mi tabla es algo asi:

id
nombre
ref
archivo_binario
archivo_nombre
archivo_peso
archivo_tipo

Por ende, mi campo "ref" no es el ID y quizas eso sea lo que afecta el funcionamiento de tu form, De hecho, para que me funcionara perfectamente, aparte de la ayuda que recibi aqui hoy, tuve que incluir el ID en el form. Espera y te paso mi codigo completo ya modificado y funcionando...
  #10 (permalink)  
Antiguo 30/09/2006, 19:18
 
Fecha de Ingreso: noviembre-2002
Ubicación: Colombia
Mensajes: 278
Antigüedad: 22 años
Puntos: 0
este es mi modificar_depilacion.php ya arreglado y funcionando:
Código PHP:
<form action="update_depilacion.php" method="post" enctype="multipart/form-data" name="depilacion" id="depilacion">

<? 
include ("config.php");

//Creamos la sentencia SQL y la ejecutamos
$sSQL="Select ref From depilacion Order By ref ASC";
$result=mysql_query($sSQL);

echo 
'<select name="ref">';
echo 
"<option value=\"\">-- Seleccione un producto --</option>\n";

//Mostramos los registros en forma de men&uacute; desplegable
while ($row=mysql_fetch_array($result))
{echo 
'<option>'.$row["ref"];}
mysql_free_result($result)
?>

<input type="submit" name="Submit" value="Actualizar" />
</form>
y este es mi update_depilacion.php ya corregido y funcionando:
Código PHP:
<? 
include ("config.php"); 

if (isset(
$_POST['ref'])){ 
$sSQL="SELECT * FROM depilacion WHERE ref='".$_POST['ref']."'"
$result=mysql_query($sSQL); 
$row=mysql_fetch_array($result); 

?>

<form action="change_depilacion.php" method="post" enctype="multipart/form-data" name="depilacion" id="depilacion">

<input name="id" type="text" id="id" value="<? echo $row['id']; ?>" size="5" />

<input name="nombre" type="text" id="nombre" value="<? echo $row['nombre']; ?>" size="35" />

<input name="ref" type="text" id="ref" value="<? echo $row['ref']; ?>" size="5" />

<input type="submit" name="Submit" value="Actualizar" />
</form>
Me toco colocar mi ID tambien en el form porque aunque si lo recibia lleno de informacion, no me procesaba bien el Update en el archivo change_depilacion.php

Te lo paso tambien por si lo requieres:
Código PHP:
<?
include ("config.php");

//Creamos la sentencia SQL y la ejecutamos
$sSQL="Update depilacion Set nombre='$nombre', ref='$ref' Where id='$id'";
mysql_query($sSQL);
?>
  #11 (permalink)  
Antiguo 01/10/2006, 08:48
 
Fecha de Ingreso: septiembre-2006
Mensajes: 196
Antigüedad: 18 años, 2 meses
Puntos: 0
mcuhas xcias iarreta vere si ahora me funciona
  #12 (permalink)  
Antiguo 01/10/2006, 08:55
 
Fecha de Ingreso: noviembre-2002
Ubicación: Colombia
Mensajes: 278
Antigüedad: 22 años
Puntos: 0
estoy en linea. cualquier cosa avisas
  #13 (permalink)  
Antiguo 01/10/2006, 13:24
 
Fecha de Ingreso: septiembre-2006
Mensajes: 196
Antigüedad: 18 años, 2 meses
Puntos: 0
mm no hay caso nose pk no me funciona, revis hasta mi php.ini para ver estado de mi register_globals y esta On
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 13:08.