MySQL - 从URL ID中选择行值

问题描述 投票:0回答:2

我创建了一个通过表单更新的表,并为每一行分配了一个特定的数字。

查看此表时,我想单击该分配的编号并获取一个页面,其中显示该行的所有详细信息。

如果我做$sql = "SELECT * FROM clients WHERE nif_id='114522';"; - 其中nif_id是指定的数字 - 我得到该数字的值,但我需要它改变表中的每个数字。

有任何想法吗?

UPDATE

这是表格代码:

<div class="card card-body">
        <table class="table">
          <thead>
              <tr>
                  <th>NIF</th>
                  <th>Nome</th>
                  <th>Apelido</th>
                  <th>Telemóvel</th>
                  <th>E-mail</th>
              </tr>
          </thead>
          <tbody>
        <?php
          include_once '../includes/db.inc.php';
          $sql = "SELECT * FROM clients ORDER BY nif_id ASC;";
          $result = mysqli_query($conn, $sql);
          $resultCheck = mysqli_num_rows($result);

          if ($resultCheck > 0) {
            while ($row = mysqli_fetch_assoc($result)) {
              $first = $row["prm_nome"];
              $last = $row["apelido"];
              $phone = $row['nmr_tlm'];
              $email = $row['mail'];
              $nif = $row['nif_id'];

              echo '<tr>';
                      echo '<td>'.$nif.'</td>';
                      echo '<td>'.$first.'</td>';
                      echo '<td>'.$last.'</td>';
                      echo '<td>'.$phone.'</td>';
                      echo '<td>'.$email.'</td>';
                      echo '</tr>';
            }
          }
         ?>
       </tbody>
       </table>
     </div>
php mysql select where
2个回答
0
投票

这是基于Web的系统的常见情况。

<div class="card card-body">
    <table class="table">
      <thead>
          <tr>
              <th>NIF</th>
              <th>Nome</th>
              <th>Apelido</th>
              <th>Telemóvel</th>
              <th>E-mail</th>
          </tr>
      </thead>
      <tbody>
    <?php
      include_once '../includes/db.inc.php';
      $sql = "SELECT * FROM clients ORDER BY nif_id ASC;";
      $result = mysqli_query($conn, $sql);
      $resultCheck = mysqli_num_rows($result);

      if ($resultCheck > 0) {
        while ($row = mysqli_fetch_assoc($result)) {
          $first = $row["prm_nome"];
          $last = $row["apelido"];
          $phone = $row['nmr_tlm'];
          $email = $row['mail'];
          $nif = $row['nif_id'];

          echo '<tr>';
                  echo '<td><a href="detail.php?nifid=' . $nif . '">'.$nif.'</a></td>';
                  echo '<td>'.$first.'</td>';
                  echo '<td>'.$last.'</td>';
                  echo '<td>'.$phone.'</td>';
                  echo '<td>'.$email.'</td>';
                  echo '</tr>';
        }
      }
     ?>
   </tbody>
   </table>
 </div>

其中detail.php是另一个页面,用于查询有关查询nifid的特定详细信息。

提醒一下,如果列的数据类型是INT,则不需要使用单引号来包围SQL语句中的值。

样本detail.php

<?php
if(!isset($_GET['nifid']) || (int)$_GET['nifid'] <= 0) {
    // Invalid or missing NIFID
    header('Location: table.php');
}
include_once '../includes/db.inc.php';
$id = (int)$_GET['nifid'];
$sql = "SELECT * FROM clients WHERE nif_id=$id";
$result = mysqli_query($conn, $sql);
$row = mysqli_fetch_assoc($result);

// TODO: display the result in whatever way you like
?>

1
投票

您可以使用get请求参数。

例如:www.myapp.com/table?id = 3920393

在PHP文件中添加功能,如下所示

if(isset($_GET["id"])){ 
   $id = $_GET["id"];
   $sql = "SELECT * FROM clients WHERE nif_id='".$id."';";

  //make db call & display HTML
}

这是一个非常简单的实现,不实现任何安全性或SQL注入安全性。对于如何解决问题,这更像是一个概念性答案。

© www.soinside.com 2019 - 2024. All rights reserved.