Foros del Web » Programando para Internet » PHP »

PHPMyAdmin Formulario

Estas en el tema de PHPMyAdmin Formulario en el foro de PHP en Foros del Web. Buenas, necesito saber cómo le hago para que en un formulario cuando se envíen los input vacíos simplemente mande un mensaje de que no se ...
  #1 (permalink)  
Antiguo 04/04/2015, 16:16
Avatar de Novato45  
Fecha de Ingreso: abril-2015
Mensajes: 37
Antigüedad: 9 años, 7 meses
Puntos: 0
PHPMyAdmin Formulario

Buenas, necesito saber cómo le hago para que en un formulario cuando se envíen los input vacíos simplemente mande un mensaje de que no se registró nada en la base de datos, esto es lo que hice:

if(!empty ($_POST['can']) && !empty ($_POST['met']) && !empty ($_POST['info']) && !empty ($_POST['fech']))
{
echo "No se registró ningún dato";
mysql_close($conexion);
}
else
{
//Aquí es cuando los input no están vacíos y registra en la BD, esto si funciona//
}
  #2 (permalink)  
Antiguo 04/04/2015, 16:39
(Desactivado)
 
Fecha de Ingreso: abril-2015
Ubicación: España
Mensajes: 616
Antigüedad: 9 años, 7 meses
Puntos: 74
Respuesta: PHPMyAdmin Formulario

prueba de sustituir el !empty() por isset()

te recomiendo que uses algún framework como Yii framework. Las validaciones son muy fáciles.

Última edición por superweb360; 04/04/2015 a las 16:52
  #3 (permalink)  
Antiguo 04/04/2015, 17:24
Avatar de Novato45  
Fecha de Ingreso: abril-2015
Mensajes: 37
Antigüedad: 9 años, 7 meses
Puntos: 0
Respuesta: PHPMyAdmin Formulario

Oye, ahora lo que hace es que siempre corre el if, deje o no deje los campos vacíos muestra el mensaje de "No se registró ningún dato" y no registra nada en la base de datos.
  #4 (permalink)  
Antiguo 04/04/2015, 17:37
(Desactivado)
 
Fecha de Ingreso: abril-2015
Ubicación: España
Mensajes: 616
Antigüedad: 9 años, 7 meses
Puntos: 74
Respuesta: PHPMyAdmin Formulario

Cita:
Iniciado por Novato45 Ver Mensaje
Oye, ahora lo que hace es que siempre corre el if, deje o no deje los campos vacíos muestra el mensaje de "No se registró ningún dato" y no registra nada en la base de datos.
Tengo mis dudas. Prueba de volver a poner empty() pero sin los signos de exclamación
  #5 (permalink)  
Antiguo 04/04/2015, 17:39
Avatar de rodrypaladin
Moderador
 
Fecha de Ingreso: abril-2010
Ubicación: Madrid
Mensajes: 2.127
Antigüedad: 14 años, 7 meses
Puntos: 468
Respuesta: PHPMyAdmin Formulario

Código PHP:
Ver original
  1. if(!isset($_POST["name"])) {
  2. echo "La variable no está definida";
  3. } else {
  4.     echo "datos enviados";
  5.     }
__________________
No te olvides de dar +1 a quien te echa un cable ;)
  #6 (permalink)  
Antiguo 04/04/2015, 17:47
Avatar de Novato45  
Fecha de Ingreso: abril-2015
Mensajes: 37
Antigüedad: 9 años, 7 meses
Puntos: 0
Respuesta: PHPMyAdmin Formulario

Ahora registra todo, y si mando el formulario vacío también lo registra :(
  #7 (permalink)  
Antiguo 04/04/2015, 17:53
(Desactivado)
 
Fecha de Ingreso: abril-2015
Ubicación: España
Mensajes: 616
Antigüedad: 9 años, 7 meses
Puntos: 74
Respuesta: PHPMyAdmin Formulario

Cita:
Iniciado por Novato45 Ver Mensaje
Ahora registra todo, y si mando el formulario vacío también lo registra :(
Prueba de quitar las exclamaciones y cambiar los && por ||

Código PHP:
Ver original
  1. if(empty ($_POST['can']) || empty ($_POST['met']) || empty ($_POST['info']) || empty ($_POST['fech']))
  2. {
  3. echo "No se registró ningún dato";
  4. mysql_close($conexion);
  5. }
  6. else
  7. {
  8. //Aquí es cuando los input no están vacíos y registra en la BD, esto si funciona//
  9. }

perdona si te lío, es que aún no tengo muy claro lo que ocurre
  #8 (permalink)  
Antiguo 04/04/2015, 17:57
Avatar de Novato45  
Fecha de Ingreso: abril-2015
Mensajes: 37
Antigüedad: 9 años, 7 meses
Puntos: 0
Respuesta: PHPMyAdmin Formulario

Descuida, lo intentaré, comoquiera te dejo este código, aquí siempre sale que no registra nada, independientemente que deje o no los campos vacíos:

<?php
$conexion=mysql_connect("localhost","root","54321" ) or die ("Problemas en la conexion");
mysql_select_db("registros", $conexion) or die ("Problemas en la seleccion de la base de datos");
if(!isset($_POST["can"]) && !isset($_POST["met"]) && !isset($_POST["info"]) && !isset($_POST["fech"]))
{
mysql_query("insert into ent(can,met,info,fech) values ('$_REQUEST[can]','$_REQUEST[met]','$_REQUEST[info]','$_REQUEST[fech]')", $conexion) or die ("Problemas en el select".mysql_error());
$resultado = mysql_query("SELECT total FROM tot", $conexion);
while ($fila = mysql_fetch_assoc($resultado))
{
$uno=$fila['total'];
}
$resultado = mysql_query("SELECT can FROM ent", $conexion);
while ($fila = mysql_fetch_assoc($resultado))
{
$dos=$fila['can'];
}
$sum = $uno + $dos;
echo "Suma: $sum";
mysql_query("UPDATE tot SET total=$sum", $conexion) or die ("Problemas al actualizar".mysql_error());
}
else
{
echo "No se registró";
}
mysql_close($conexion);
?>
  #9 (permalink)  
Antiguo 04/04/2015, 17:59
Avatar de rodrypaladin
Moderador
 
Fecha de Ingreso: abril-2010
Ubicación: Madrid
Mensajes: 2.127
Antigüedad: 14 años, 7 meses
Puntos: 468
Respuesta: PHPMyAdmin Formulario

EL operador lógico && da como valor boleano TRUE si tanto $a como $b son TRUE, y no es el que tendrías que usar, pues tu buscas que si cualquiera de esas posibilidades es true, haga una acción, y para eso se usa || o OR

Manual sobre Operadores Lógicos
__________________
No te olvides de dar +1 a quien te echa un cable ;)
  #10 (permalink)  
Antiguo 04/04/2015, 18:00
Avatar de Novato45  
Fecha de Ingreso: abril-2015
Mensajes: 37
Antigüedad: 9 años, 7 meses
Puntos: 0
Respuesta: PHPMyAdmin Formulario

Ya funcionó, si era con "empty" y "||", de nuevo gracias.
  #11 (permalink)  
Antiguo 04/04/2015, 19:30
Avatar de rodrypaladin
Moderador
 
Fecha de Ingreso: abril-2010
Ubicación: Madrid
Mensajes: 2.127
Antigüedad: 14 años, 7 meses
Puntos: 468
Respuesta: PHPMyAdmin Formulario

También te habría servido usar isset() pero era el operador lógico erróneo
__________________
No te olvides de dar +1 a quien te echa un cable ;)

Etiquetas: formulario, mysql, phpmyadmin
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 14:11.