MySQL-从网址ID

时间:2019-03-08 02:12:11

标签: php mysql select where

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

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

如果我执行$sql = "SELECT * FROM clients WHERE nif_id='114522';";(其中nif_id是已分配的数字),则可以获取该数字的值,但是我需要对表中的每个数字进行更改。

有什么想法吗?

更新

这是表格代码:

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

2 个答案:

答案 0 :(得分:1)

您可以使用get request参数。

例如: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注入安全性。这更多是关于如何解决问题的概念性答案。

答案 1 :(得分: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
?>