Jump to content
leocouto

Pegar último dado específico de uma tabela.

Recommended Posts

Pegar um dado específico de uma tabela, caso tenha mais de um item cadastrado sempre vai pegar o último.

<form name="editaFornecedor"<?php +1?> action="edit_forne.php" id="editaFornecedor" method="POST">
             <!-- Pegando todos os fornecedores cadastrados... -->
              <table class="table table-striped">
                    <thead class="thead-dark">
                        <tr>
                            <th scope="col">ID</th>
                          <th scope="col">Nome</th>
                          <th scope="col">Fone</th>
                          <th scope="col">CNPJ</th>
                          <th scope="col">Rua</th>
                          <th scope="col">Número</th>
                          <th scope="col">Bairro</th>
                          <th scope="col">Estado</th>
                          <th scope="col">Cidade</th>
                          <th scope="col">CEP</th>
                          <th scope="col">E-mail</th>
                          <th scope="col">Observação</th>
                          <th scope="col">Editar|Deletar</th>
                        </tr>
                    </thead>
                <?php
                    @session_start();
                    include('conexao.php');

                    $fornecedor = mysqli_query($conexao, "SELECT * FROM fornecedor");

                    $linhas = mysqli_num_rows($fornecedor);

                    while ($linhas = mysqli_fetch_array($fornecedor)) {
                        
                ?>
                    <tbody>
                        <tr>
                          <td><?php echo $linhas['id_fornecedor']; ?></td>
                          <td><?php echo $linhas['nome']; ?></td>
                          <td><?php echo $linhas['fone']; ?></td>
                          <td><?php echo $linhas['cnpj']; ?></td>
                          <td><?php echo $linhas['rua']; ?></td>
                          <td><?php echo $linhas['numero']; ?></td>
                          <td><?php echo $linhas['bairro']; ?></td>
                          <td><?php echo $linhas['estado']; ?></td>
                          <td><?php echo $linhas['cidade']; ?></td>
                          <td><?php echo $linhas['cep']; ?></td>
                          <td><?php echo $linhas['email']; ?></td>
                          <td><?php echo $linhas['observacao']; ?></td>
                          <td>
                            <button type="submit" class="btn btn-secondary" style="height: 35px; width: 100px"><i class="material-icons">description</i>Editar</button><br>
                            <button type="button" class="btn btn-danger" style="height: 35px; width: 100px"><i class="material-icons">delete</i>Deletar</button>
                        </td>
                        <td><input type="text" name="id_fornecedor" value="<?php echo $linhas['id_fornecedor'];?>"></td>
                        </tr>
                    </tbody>
                    
                <?php 
                    }
                ?>
                </table>
            <!-- Fim da exibição de todos os fornecedores cadastrados.. -->
            </form>

 

 

======================================================================================================================================================

Aqui no MYSQL só pega o último item da tabela.. Não pega o que foi clicado no botão.

<?php
include('conexao.php');
session_start();

//$cnpj=$_POST['cnpj'];
$id_fornecedor=$_POST['id_fornecedor'];
echo $id_fornecedor;

?>

=======================================================================================================================================================

É desse modelo da imagem, mas na hora que clico em editar no mysql aparece o último id e não na linha que cliquei, se eu clicar no primeiro na outra página aparece o id 4, que é o ultimo, quem pode me dar essa força? Ficarei muito grato.

image.thumb.png.5754caacf45ab0f0c15a6a7ea1fcd909.png

Share this post


Link to post
Share on other sites

@leocouto Bom dia!

 

Bom o que está acontecendo, é que quando você faz o loop dos resultados do banco de dados, você acaba adiciona dois elemento com o mesmo name(nome) = id_fornecedor em um único form, e o que está passando para a requisição post, para a página edit_forne.php é o ultimo.

 

O que está acontecendo no seu form é +- isso:

<form name="editaFornecedor" action="edit_forne.php" id="editaFornecedor" method="POST">
  	<?php while ($linhas = mysqli_fetch_array($fornecedor)) { ?>
	<input type="text" name="id_fornecedor" value="<?php echo $linhas['id_fornecedor'];?>"> 
  	<?php } ?>
</form>

// Resultado na página

<form name="editaFornecedor" action="edit_forne.php" id="editaFornecedor" method="POST">
	<input type="text" name="id_fornecedor" value="3"> 
	<input type="text" name="id_fornecedor" value="4"> <!-- O ultimo elemento com o mesmo nome vai acabar sobrescrever o valor -->
</form>

 

Para resolver isso, você tem diversas opções, você pode fazer um link e passar o id via método GET, ou adicionar um form para cada input com o name id_fornecedor.

 

 

 

 

 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By lulabel
      Necessito criar um quiz usando matriz, session e placar mas não consigo de jeito nenhum, já tentei procurar videos ou algum lugar explicando como posso fazer isso, mas até agora nada, fico travado. Sou iniciante no php ainda então qualquer ajuda é uma luz bem vinda.
    • By Dark_Trap000
      Ola, eu tenho um problema ao salvar ips permitidos no MySQL
      segue o codigo de salvamento
      <?php session_start(); include "conexao.php"; if (empty($_SESSION['usuario'])) { header('Location: login.php'); exit(); } $ip = $_SESSION['ip']; echo $pegar_ip = $_SERVER["REMOTE_ADDR"]; if($ip == $pegar_ip) { echo "IP Autorizado!!!"; } else if($ip == 0) { $pegar_ip = $_SERVER["REMOTE_ADDR"]; echo "IP Não Registrado!!!"; $sql = "UPDATE usuario SET creditos = $salvar WHERE usuario_id = $id"; die(); } ?> ele chega á estar tudo certo, + o problema e salvar no mysql. qual o problema ?
    • By violin101
      Caros amigos, membros do grupo, saudações...
       
      Se postei minha dúvida na opção errada peço desculpa.
       
      Estou com uma pequena dúvida.
       
      Quando cadastro usuários na MySql utilizo PASSWORD_HASH para criptografar a Senha.
       
      Estou montando uma rotina, onde o usuário que esqueceu sua senha o sistema envia por e-mail a sua senha, mas me deparei com um pequeno problema.
       
      a senha criada pelo usuário, como por exemplo: 12345678 usando o PASSWORD_HASH fica desta forma: $2y$10$ukBckA5D2aSApHwv/GOKi.P/drP.jwAHOK/9SmWIgRxLUE.x9z.ZK
       
      Quando tento enviar a senha para o usuário vai conforme acima, preciso enviar apenas 12345678. Como consigo descriptografar o PASSWORD_HASH ?
       
      Grato,
       
      Cesar
    • By elisandrodceza
      Alguma ideia para pesquisar os $id recebidos por get em um arquivo diferente ? como se percebe no código funcional a baixo, os $id estão duplicados para funções diferente. Quero adicionar eles em outro arquivo para uma melhor organização com as variáveis $id e $client,  mas de uma maneira que possa pesquisar tanto qual é a $id e o $client para ser informado por email quando o client ler o qrcode, quanto se a $id está na lista para ser redirecionado.
       
       
      ARQUIVO auth_code.php
       
      <?php
          $id = $_GET['id'];
          $ip = $_SERVER['REMOTE_ADDR'];
          $browser = $_SERVER['HTTP_USER_AGENT'];
          $to = "suporte@eatech.inf.br";
          $success = false;

              if ($id == '2623F52846F8A03DA4ADFA9392486807') $client = "Card Contato";
              if ($id == '2BDBDDA17456A1060E156BE7A487FC') $client = "Client 1";
              if ($id == 'E7EA229948A4997C2F72219D6A2764') $client = "Client 2";
              if ($id == '07118879907903166B2C3BE7408EFD') $client = "Client 3";
              if ($id == 'FED09C7CC40ACD77A0BDEA57E894A3') $client = "Client 4";
              if ($id == 'C042D3187B52E87D6E6196567101EF') $client = "Client 5";
              if ($id == '7DCD0215BEC8AF587AD886E407A485') $client = "Client 6";
       
          $messagem = "Cliente: $client<br><br>ID: $id<br><br>IP: $ip<br><br>Browser: $browser"; 
          $assunto = "qrCode digitalizado";
          $headers = "MIME-Version: 1.0\n";
          $headers .= "Content-type: text/html; charset=iso-8859-1\n";
          $headers .= "From: $client\n";
          
          $success = mail($to, $assunto, $messagem, $headers);
          
          if ($id == '2623F52846F8A03DA4ADFA9392486807')
              { header('Location: download/contato.vcf');}
       
          else
              if (

              $id == '2BDBDDA17456A1060E156BE7A487FC' # Client 1
              or $id == 'E7EA229948A4997C2F72219D6A2764' # Client 2
              or $id == '07118879907903166B2C3BE7408EFD' # Client 3
              or $id == 'FED09C7CC40ACD77A0BDEA57E894A3' # Client 4
              or $id == 'C042D3187B52E87D6E6196567101EF' # Client 5
              or $id == '7DCD0215BEC8AF587AD886E407A485' # Client 6
              )
              { header('Location: download/index.php?id=' . $id. '.pdf');}
       
          else
              { echo "<script>alert('Este qrCode ainda não está cadastrado no sistema, tente novamente mais tarde!');history.go(-1) </script>";}
      ?>
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.