Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Devolver valor NULL en input

Estas en el tema de Devolver valor NULL en input en el foro de PHP en Foros del Web. Hola, No consigo que un input vacío me devuelva el valor NULL, siempre me devuelve un 0. He probado con algo sencillo así: Código PHP: ...
  #1 (permalink)  
Antiguo 16/10/2013, 04:28
 
Fecha de Ingreso: enero-2012
Mensajes: 88
Antigüedad: 12 años, 3 meses
Puntos: 1
Devolver valor NULL en input

Hola,

No consigo que un input vacío me devuelva el valor NULL, siempre me devuelve un 0.

He probado con algo sencillo así:

Código PHP:
$gollocal $_POST['glocal'];
$golvisitante $_POST['gvisitante'];

for (
$i=1;$i<=8;$i++) {
      
    if (empty(
$gollocal[$i])){
    
$gollocal[$i]=NULL;
    }
    
    if (empty(
$golvisitante[$i])){
    
$golvisitante[$i]=NULL;
    }

        
$sqlupdate...

Pero siempre me toma el valor 0, y al ser parte de un sistema de resultados deportivos pues el 0 "tiene valor". ¿Igual abría que modificar algo en la parte del formulario y no en la que recoge los resultados?

Un saludo
  #2 (permalink)  
Antiguo 16/10/2013, 04:31
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 15 años, 8 meses
Puntos: 2237
Respuesta: Devolver valor NULL en input

Yo creo que el problema es por la definición de la tabla, seguramente los campos son numéricos y no permiten valor nulo o tienen asignado el cero como valor por defecto.

Muestra la estructura de tu tabla para corroborarlo.
__________________
- León, Guanajuato
- GV-Foto
  #3 (permalink)  
Antiguo 16/10/2013, 04:37
 
Fecha de Ingreso: enero-2012
Mensajes: 88
Antigüedad: 12 años, 3 meses
Puntos: 1
Respuesta: Devolver valor NULL en input

Si que tiene puesto valor NULL por defecto, te dejo la tabla:
CREATE TABLE `liga_calendario` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`temporada` int(11) NOT NULL DEFAULT '2012',
`jornada` int(4) NOT NULL,
`eq_local` int(11) NOT NULL,
`goles_local` int(4) DEFAULT NULL,
`eq_visitante` int(11) NOT NULL,
`goles_visitante` int(4) DEFAULT NULL,
`pabellon` int(11) DEFAULT NULL,
`fecha_hora` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
PRIMARY KEY (`id`)
)
  #4 (permalink)  
Antiguo 16/10/2013, 04:38
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 15 años, 8 meses
Puntos: 2237
Respuesta: Devolver valor NULL en input

Ok, entonces muestra cómo armas la consulta.
__________________
- León, Guanajuato
- GV-Foto
  #5 (permalink)  
Antiguo 16/10/2013, 04:42
 
Fecha de Ingreso: enero-2012
Mensajes: 88
Antigüedad: 12 años, 3 meses
Puntos: 1
Respuesta: Devolver valor NULL en input

Es una consulta sencilla:

$sqlupdate ="UPDATE liga_calendario SET goles_local='".$gollocal[$i]."',goles_visitante='".$golvisitante[$i]."' WHERE id='".$ids[$i]."'";
$resultupdate = mysql_query($sqlupdate);

(Ya sé que tengo que actualizar a mysqli_query, pero aún no lo he estudiado...)
  #6 (permalink)  
Antiguo 16/10/2013, 04:55
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 15 años, 8 meses
Puntos: 2237
Respuesta: Devolver valor NULL en input

Si la columna es numérica, porqué encierras los valores entre comillas?

'NULL' no es igual a NULL y tal vez MySQL intenta convertir a número, resultando en cero.

Tu código debería ser más o menós así:

Código PHP:
Ver original
  1. if (empty($gollocal[$i])){
  2.             // Entre comillas, porque el NULL de PHP no es igual al de MySQL
  3.             $gollocal[$i] = 'NULL';
  4.     }
  5.  
  6. // Luego, en la consulta:
  7. $sqlupdate ="UPDATE liga_calendario SET goles_local={$gollocal[$i]}, goles_visitante={$golvisitante[$i]} WHERE id='".$ids[$i]."'";

Las llaves te permiten integrar elementos de array() en una cadena para que sean interpretados.
__________________
- León, Guanajuato
- GV-Foto
  #7 (permalink)  
Antiguo 16/10/2013, 05:01
 
Fecha de Ingreso: enero-2012
Mensajes: 88
Antigüedad: 12 años, 3 meses
Puntos: 1
Respuesta: Devolver valor NULL en input

Muchisimas gracias! Ahora funciona correctamente. La verdad es que aún estoy aprendiendo sobre PHP y MySql y por eso esos detalles de las comillas o las llaves no los conozco.

Muchas gracias de nuevo
  #8 (permalink)  
Antiguo 16/10/2013, 05:15
 
Fecha de Ingreso: enero-2012
Mensajes: 88
Antigüedad: 12 años, 3 meses
Puntos: 1
Respuesta: Devolver valor NULL en input

Me acabo de dar cuenta de una cosa, al pasar el valor 0 me lo cuenta como un NULL :S

Etiquetas: devolver, formulario, input, null, sql, valor
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 07:00.