Foros del Web » Programando para Internet » PHP »

problemas con el update

Estas en el tema de problemas con el update en el foro de PHP en Foros del Web. Tengo un problema con el update. Tengo un formulario que recoge los datos que van a ser modificados, y los envía a editar.php, que es ...
  #1 (permalink)  
Antiguo 01/07/2011, 11:07
 
Fecha de Ingreso: junio-2011
Ubicación: Asturias
Mensajes: 228
Antigüedad: 12 años, 10 meses
Puntos: 14
problemas con el update

Tengo un problema con el update.
Tengo un formulario que recoge los datos que van a ser modificados, y los envía a editar.php, que es el mismo archivo que estoy ejecutando.

Le paso por url el id de la fila que quiero modificar, pero cuando lo ejecuto, me dice que la variable de id no está definida(porque como dije, el formulario redirige a editar.php sin más nada)

Entonces no me modifica nada.
Est es todo mi codigo.

<?
include("conexion.php");
$link=conectarse();
?>
<html>
<head>
<title>Editar</title>
<link href="estilo.css" rel="stylesheet" type="text/css">
</head>
<body class="body">
<div class="contenedor">
<div class="cabecera">
</div>
<?
include "left.php";
?>
<div class="principal">
<?
if( isset ($_POST['nombre']) && isset ($_POST['descripcion']) && isset ($_POST['codigo']) )
{
echo "hola";
$ptcid = $_GET['id'];
$nombre=mysql_real_escape_string($_POST['nombre']);
$descripcion=mysql_real_escape_string($_POST['descripcion']);
$codigo=mysql_real_escape_string($_POST['codigo']);
$sql="update datos Set nombre='$nombre',descripcion='$descripcion', codigo='$codigo' where id_ptc = $ptcid";
mysql_query($sql,$link);
echo "Datos borrados correctamente";

}
?>
</div>

<form method="post" ACTION="editar.php">
Nombre de la PTC
<input type="text" name="nombre" >
<br>
<br>
Descripción
<input type="text" name="descripcion" >
<br>
<br>
Codigo
<input type="text" name="codigo" >
<br>
<br>
<input type="submit" name="accion" value="enviar">
</form>
</div>


</body>
</html>

Gracias de antemano
  #2 (permalink)  
Antiguo 01/07/2011, 11:13
 
Fecha de Ingreso: abril-2009
Ubicación: Colombia
Mensajes: 949
Antigüedad: 15 años
Puntos: 27
Respuesta: problemas con el update

Estas enviando con POST y recibiendo con GET....Eso es error...
Ademas fijate que estas recibiendo algo llamado id que nunca estas enviando

Coloca asi:

Código HTML:
Ver original
  1. <input type="text" name="nombre" id="nombre" >

Código PHP:
Ver original
  1. if (isset($_POST['nombre']))
  2.  
  3. {
  4.  $nombre=$_POST['nombre'];
  5. echo $nombre;
  6.  
  7. }
  #3 (permalink)  
Antiguo 01/07/2011, 11:15
 
Fecha de Ingreso: abril-2009
Ubicación: Colombia
Mensajes: 949
Antigüedad: 15 años
Puntos: 27
Respuesta: problemas con el update

Aaa y de donde sacas el id?...ese id esta en la tabla de la base de datos?.....
  #4 (permalink)  
Antiguo 02/07/2011, 04:51
 
Fecha de Ingreso: junio-2011
Ubicación: Asturias
Mensajes: 228
Antigüedad: 12 años, 10 meses
Puntos: 14
Respuesta: problemas con el update

no, el id viene de la url editar.php?id=xx
  #5 (permalink)  
Antiguo 02/07/2011, 17:09
 
Fecha de Ingreso: mayo-2011
Ubicación: Mexico
Mensajes: 22
Antigüedad: 12 años, 11 meses
Puntos: 2
Respuesta: problemas con el update

tiene razon mi amigo de arriba el id se supone que tu lo tienes que llamar desde tu base de datos y creo que la mejor forma seria hacer una consulta hacia tu base de datos y encriptar el id en la variable editar algo asi:

<?
include("conex.php"); --en caso tu conexion a la base de datos ok
$link=conectarse();
$result=mysql_query("select id from usuarios",$link); seleccionas el id de la base da datos
?>
<TABLE BORDER=3 CELLSPACING=1 CELLPADDING=1> --- creas una tabla
<TR><TD>&nbsp;<B>Actualizar_Datos</B></TD></TR>
<?php
while($row = mysql_fetch_array($result)) {
printf("<tr><td><a href=\"Actualizar/Actualizar_datos.php?id=%d\">y el id lo encriptas de esta manera ok y le cambias el nombre de la pagina a la que vas a redireccionar los datos actuales por los nuevo ok puedes agregarle mas campos si quieres
<center>Actualizar</center></a></td></tr>",$row["id"]);
}
mysql_free_result($result);
mysql_close($link);
?>

este codigo aclao solo hace la consulta de ala base de datos para llamar ya sea el usuario y su datos depandiendo el id seleccionado ok

y aqui te dejo el otro codigo para llamar los datos: y para actualizar ok

<?php
$cn=mysql_connect("localhost","root","1234")or die("Error conexion MySQL");
$db=mysql_select_db("usuarios",$cn)or die("No existe BD");
$ida=$_GET['id'];
$id=$ida;
$query=mysql_query("SELECT * FROM usuarios WHERE id=$id")or die("Error consulta");
$n=mysql_num_rows($query);

while($campo=mysql_fetch_array($query))
{
echo "<FORM METHOD=POST ACTION='Actualizar.php?id=%d'>"; aqui va ladireccion para realizar la actualizacion ok

echo "<TABLE width='388'><h3>";
echo "<tr>";
echo "<td><div align='left'></div></td>";
echo "<td><INPUT TYPE='hidden' NAME='login' VALUE='".$campo['login']."'></td>".$campo['login'];
echo "</tr>";

aqui puedes mandar a llamar mas campos que le pertenescan a ese id ok

echo"<center>";
echo "<tr>";
echo "<td><br><div align='center'><INPUT TYPE='submit' value='Actualizar'></div></td><br>";
echo "</FORM>";
echo "</tr>";
echo"</center>";
echo "</table></h3>";
}
?>

Bueno esta codigo te llama los datos del id seleccionado ok

y este otro hace la actualizacion:
<?php
$nombre=$_POST['nombre1'];
creas tus bariables con el metodo POST

$cn=mysql_connect("localhost","root","1234")or die("Error conexion MySQL");
$db=mysql_select_db("usuarios",$cn)or die("No existe BD");
$ida=$_SESSION['id'];
$id=$ida;
$sql = "UPDATE usuarios SET nombre='$nombre';
$sql.= " WHERE id = '$id'";
$res = mysql_query($sql);
if($res)
{
echo "<center>Datos Actualizados Correctamente</center>";
echo "<br><a href='../Perfil.php'><center>Actualizacion OK ! </center></a>";
}
else
{
echo "<a href='../Perfil.php'><center>No hubo actualizacion </center></a>";
}
?>

espero y te siva y recuerda agradecer no cuesta nada cualquier duda no dudes en preguntar ok SUERTE...

Etiquetas: update
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 12:27.