MySQL - 来自 url ID 的 Select 行值

MySQL - Select row values from url ID

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

查看此 table 时,我想单击分配的号码并获得显示该行所有详细信息的页面。

如果我这样做 $sql = "SELECT * FROM clients WHERE nif_id='114522';"; - 其中 nif_id 是分配的号码 - 我得到该号码的值,但我需要它随着 table 中的每个号码而改变.

有什么想法吗?

更新

这是 table 代码:

<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>

可以使用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 注入安全性。这更像是关于如何解决问题的概念性答案。

这对于基于 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
?>