Ir ao conteúdo
  • Cadastre-se

PHP Alteração não está permitindo campo vazio


Posts recomendados

Oi, estou em um formulário de alteração, e quando vou deixar um campo vazio ou com valor 0, ele não faz a alteração.

}
else {
			
if (isset($_POST['Alterar']) && $_POST['Alterar'] == "ok") {

$campos = array();

if (!empty($_POST['login'])) {
$campos[] = sprintf("login= '%s'", $_POST['login']);
}
if (!empty($_POST['senha'])) {
$campos[] = sprintf("senha= '%s'", sha1($_POST['senha']));
}
if (!empty($_POST['ativo'])) {
$campos[] = sprintf("ativo= '%s'", $_POST['ativo']);
}
if (!empty($_POST['id'])):
$sql = "UPDATE clientes SET ".implode(', ', $campos)." WHERE id_cliente = ".$_POST['id'];
$query = $sqli->query($sql);
else:
return false;
endif;
echo "<script> alert('Edição efetuada com sucesso! Clique em OK');</script>";
}		

?>

Se eu deixar um campo vazio como login ou senha ele não faz o update neste campo, ou no ativo que é 0 ou 1, se eu trocar o 0 por um valor 2 ele aceita, mas não o valor 0

Link para o comentário
Compartilhar em outros sites

Em 03/09/2020 às 10:50, Gugatxr disse:

Bom dia.

O empty retorna verdadeiro para casos como 0, null, string vazia.
Por isso não funciona no seu caso. 

 

Pode fazer algo assim:


if (!empty($_POST['ativo'])) {
	$campos[] = sprintf("ativo= '%s'", $_POST['ativo']);
} else {
	$campos[] = sprintf("ativo= '%s'", 0);
}

 

Oi, Obrigada, deu certo, se for para outra coisa eu apenas coloco null no lugar de 0

  • Curtir 1
Link para o comentário
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisa ser um usuário para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar agora

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...