Foros del Web » Programando para Internet » PHP »

Registro duplicado: uno vacío y otro con los datos correctos

Estas en el tema de Registro duplicado: uno vacío y otro con los datos correctos en el foro de PHP en Foros del Web. Hola a todos. Gracias por adelantado si estás mirando esta consulta. Resulta que he creado un formulario en PHP y MySql. Funciona bien, pero cuando ...
  #1 (permalink)  
Antiguo 20/01/2012, 13:24
 
Fecha de Ingreso: diciembre-2011
Ubicación: Madrid
Mensajes: 7
Antigüedad: 12 años, 11 meses
Puntos: 1
Registro duplicado: uno vacío y otro con los datos correctos

Hola a todos.

Gracias por adelantado si estás mirando esta consulta.

Resulta que he creado un formulario en PHP y MySql. Funciona bien, pero cuando presiono enviar me crea dos registros:
- El primero de los registros tiene todos los campos vacíos.
- El segundo de los registros tiene todos los campos correctos, es decir, los que he introducido a través del formulario.
Obviamente el problema es que no deseo ese registro con los campos en blanco. Os dejo aquí las partes importantes del código. Espero que alguien pueda ayudarme. Muchas gracias a todos.


Código HTML:
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Urban Cloud - Registro</title>
<link href="estilos.css" rel="stylesheet" type="text/css" />
<script language="javascript" src="js/registro.js"></script>
</head>
<body>
<center><img src="btnes/urbancloud.jpg" alt="Urban Cloud Logo" longdesc="Urban Cloud Logo" /></center>
<?php
$primeravez = FALSE;
if (empty($_POST))
{
	$primeravez = TRUE;
}
?>

bla bla bla bla

<form accept-charset="utf-8" name="formularioregistro" id="formularioregistro" method="post" action="" onsubmit="return validator();">

bla bla bla bla campos del formulario, validaciones, etc... bla bla bla

    <input type="submit" style="background-color:#53c2e0; font-size:14px; color:#ffffff" value="¡cloud!" id="¡cloud!" />

bla bla bla bla

<?php
$fecha = date("Y-n-d");
$link = mysql_connect("localhost","root","");
mysql_select_db("Urban Cloud", $link);
$sql = "INSERT INTO Usuarios (fechaalta,nombreusuario,contrasenia,mail,nombre,apellidos,pais,provincia,ciudad,sexo,anio,ong) VALUES ('$fecha','{$_POST['nombreusuario']}','{$_POST['contraseña']}','{$_POST['mail']}','{$_POST['nombre']}','{$_POST['apellidos']}','{$_POST['pais']}','{$_POST['provincia']}','{$_POST['ciudad']}','{$_POST['sexo']}','{$_POST['fechanacimientoaño']}','{$_POST['ong']}')";
$result = mysql_query($sql);
echo "¡Gracias! Hemos recibido sus datos.\n";
?> 
  #2 (permalink)  
Antiguo 20/01/2012, 13:30
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años, 7 meses
Puntos: 2534
Respuesta: Registro duplicado: uno vacío y otro con los datos correctos

El problema es que de ninguna forma estás condicionando el INSERT, por eso se duplica... de hecho, te aseguro que si recargas 10 veces tu pagina creará 10 registro vacíos.

Ya tienes una variable $primeravez que te debería servir para lo mismo.
Código PHP:
if ( ! $primeravez ) {
  
// INSERT

Como puedes notar tu problema no es de código, es de lógica.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 20/01/2012, 13:36
 
Fecha de Ingreso: enero-2011
Mensajes: 46
Antigüedad: 13 años, 10 meses
Puntos: 2
Respuesta: Registro duplicado: uno vacío y otro con los datos correctos

al ingresar por primera vez a tu página mandas a guardar y cuando le das click al botón también! como dice pateketrueke. es un problema de lógica
  #4 (permalink)  
Antiguo 20/01/2012, 14:17
 
Fecha de Ingreso: diciembre-2011
Ubicación: Madrid
Mensajes: 7
Antigüedad: 12 años, 11 meses
Puntos: 1
Respuesta: Registro duplicado: uno vacío y otro con los datos correctos

Vaya, es lo que tiene meterse a programar sin tener ni idea y por tu cuenta y riesgo, que cometes errores de pardillo.

Muchas gracias pateketrueke y eldan2002, por la eficacia y la rapidez de respuesta.

Saludos
  #5 (permalink)  
Antiguo 20/01/2012, 15:14
 
Fecha de Ingreso: enero-2011
Mensajes: 46
Antigüedad: 13 años, 10 meses
Puntos: 2
Respuesta: Registro duplicado: uno vacío y otro con los datos correctos

siempre a la orden. y al igual que tú todos pasamos por esos errores de pardillo como tu le llamas. suerte!

Etiquetas: mysql, registrodoble
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:29.