Editar dados no php/mysql
Pessoal, sou iniciante em programação e estou fazendo o site de casamento da minha irmã.
Fiz uma página onde os convidados confirmam sua presença.
Primeiro eles pesquisam pelo nome e na frente do nome, clicando em alterar, tem uma caixa de seleção que pode ser escolhido entre pendente e confirmado (Foi o unico modo que consegui fazer, mesmo não sendo o mais intuitivo).
Consegui fazer a pesquisa e tudo certo, o problema é na hora da alteração mesmo, não sei o que esta acontecendo que depois de tudo ele acaba não alterando no banco de dados. Acho que eu não estou manipulando corretamente a variável.
Link da pagina de confirmação de presença: http://www.casamentobiaecarlos.com.br/confirme-sua-presenca/ (tem algumas pessoas cadastradas, pesquisem por ana)
Estou usando worpress.
Código da página de pesquisa:
<h4 style="text-align: center;">Pesquise seu nome ou pelo nome de sua família para confirmar a presença!</h4>
<div align="center"><form action="" method="POST"><input name="nome" size="20" type="text" placeholder="Digite o nome" />
<input name="SendPesqUser" type="submit" value="Pesquisar" /></form>
<hr />
<?php
include_once "conexao.php";
$SendPesqUser = filter_input(INPUT_POST, 'SendPesqUser', FILTER_SANITIZE_STRING);
if($SendPesqUser){
$nome = filter_input(INPUT_POST, 'nome', FILTER_SANITIZE_STRING);
$result_usuario = "SELECT * FROM lista_presenca WHERE nome LIKE '%$nome%'";
$resultado_usuario = mysqli_query($conn, $result_usuario);
while($row_usuario = mysqli_fetch_assoc($resultado_usuario)){
echo utf8_encode ($row_usuario['nome'] . " - " . $row_usuario['status'] . " | <a href='http://www.casamentobiaecarlos.com.br/editar-presenca/?id=" . $row_usuario['id'] . "'>Alterar</a><br><br>");
}
if ($result_usuario == 0) {
echo "Se não foi encontrado nenhum registro com seu nome, tente novamente ou <a href='solicite.php'>clique aqui</a> e solicite sua inclusão na lista.";
}
}
?>
<?php
session_start();
include_once("conexao.php");
$id = filter_input(INPUT_GET, 'id', FILTER_SANITIZE_NUMBER_INT);
$result_usuario = "SELECT * FROM lista_presenca WHERE id = '$id'";
$resultado_usuario = mysqli_query($conn, $result_usuario);
$row_usuario = mysqli_fetch_assoc($resultado_usuario);
if(isset($_SESSION['msg'])){
echo $_SESSION['msg'];
unset($_SESSION['msg']);
}
?>
<form method="POST" action="http://www.casamentobiaecarlos.com.br/edit_presenca.php">
<p>
<input type="hidden" name="id" value="<?php echo $row_usuario['id']; ?>">
<center>
<label><?php echo $row_usuario['nome']; ?><br><hr><br>
</label>
<label for="status"></label>
<select name="status" id="status">
<option><?php echo $row_usuario['status']; ?></option>
<option>Pendente</option>
<option>Confirmado</option>
</select>
<br>
<br>
<input type="submit" value="Alterar">
</center>
</p>
</form>
Código da página de alteração: ^^
Código da página de alteração no banco de dados:
<?php
session_start();
include_once("conexao.php");
$id = filter_input(INPUT_POST, 'id', FILTER_SANITIZE_NUMBER_INT);
$nome = filter_input(INPUT_POST, 'nome', FILTER_SANITIZE_STRING);
$status = filter_input(INPUT_POST, 'status', FILTER_SANITIZE_EMAIL);
//echo "Nome: $nome <br>";
//echo "Status: $status <br>";
$result_usuario = "UPDATE lista_presenca SET nome='$nome', status='$status', modified=NOW() WHERE id='$id'";
$resultado_usuario = mysqli_query($conn, $result_usuario);
if(mysqli_affected_rows($conn)){
$_SESSION['msg'] = "<p style='color:green;'>Alteração na presença feita com sucesso!</p>";
header("Location: http://www.casamentobiaecarlos.com.br/");}else{
$_SESSION['msg'] = "<p style='color:green;'>Ocorreu um erro! Tente novamente.</p>";
header("Location: http://www.casamentobiaecarlos.com.br/editar-presenca/?id=$id");
}Discussão (3)
Carregando comentários...