如何更改While循环内的单行数组变量并使用新结果更新数据库表

时间:2017-09-06 00:44:56

标签: php mysql arrays loops foreach

结束时HTML表结果的图片

以下完整代码 - 按订单排序。注意 - 我可以轻松更改所有ROWS并在HTML TABLE中显示。诀窍,至少对我来说,只是将一行更改为新值。

  <?php
  session_start();

  $db = new mysqli('localhost', 'my_user', 'my_password', 'my_db');

  $stmt = $db->prepare("SELECT id_ai, name, age, agender, $flex,hsp_plan,hcs_plan FROM quotes ");
  $stmt->execute();
  $stmt->bind_result($id_ai, $name, $age, $agender, $flex,$hsp_plan,$hcs_plan);
  $stmt->store_result();

  echo 
  "<div class='table-responsive'>
  <table id='myTable' class='table table-striped table-bordered'>
  <p><font color='#4169e1'></font></p>
  <thead>
  <tr>
  <th>ID</th>
  <th>Name</th>
  <th>Age</th>
  <th>Gender</th>
  <th>Flex</th>
  <th>HSP</th>
  <th>HCS</th>
  </tr>
  </thead>
  <tbody>";

我在echo表标题后启动while循环,因此它只打印一次。 然后我开始循环

  while ($stmt->fetch()){

     $_SESSION['id_ai'] = $id_ai;
     $_SESSION['name']= $name;
     $_SESSION['age']= $age;
     $_SESSION['agender']= $agender;
     $_SESSION['flex']= $flex;
     $_SESSION['hsp_plan']= $hsp_plan;
     $_SESSION['hcs_plan']= $hcs_plan;

   $id_ai    = $_SESSION['id_ai'];
   $name     = $_SESSION['name'];
   $age      = $_SESSION['age'];
   $agender  = $_SESSION['agender'];
   $flex     = $_SESSION['flex'];
   $hsp_plan = $_SESSION['hsp_plan'];
   $hcs_plan = $_SESSION['hcs_plan'];

  $hsp_plan = mysqli_real_escape_string($db, $_SESSION['hsp_plan']);
  $hcs_plan = mysqli_real_escape_string($db, $_SESSION['hcs_plan']);
  $age      = mysqli_real_escape_string($db, $_SESSION['age']);
  $agender  = mysqli_real_escape_string($db, $_SESSION['agender']);

我使用变量来查询数据库表。工作完美。我得到了重复的定价97.09 97.09作为结果 - FOREACH纠正了这个问题。

  $hsp_query = mysqli_query($db,"Select sum($agender * 1 ) FROM $hsp_plan WHERE age = $age ");         
     $hsp = mysqli_fetch_array($hsp_query, MYSQLI_BOTH);                

    foreach($hsp as $key => $value)
        {
            $hsp_a = explode(' ', trim($value));
                $hsp_b[$hsp_a[1]] = $hsp_a[0];                
            $hsp_price = implode(' ', $hsp_b);
        }  

我使用新结果插入/更新表。

  $sql = "INSERT INTO quotes (id_ai, id, name, age, agender, flex,hsp,hcs,bal, hsp_plan, hcs_plan) VALUES ('$id_ai', '$id_ai', '$name', '$age','$agender','$flex', '$hsp_price', '$hcs_price', '$hsp_plan','$hcs_plan')
        ON DUPLICATE KEY UPDATE `id_ai`='$id_ai', `id`='$id_ai', `name`='$name', `age`='$age', `agender`='$agender', `flex`='$flex', `hsp`='$hsp_price', `hcs`='$hcs_price', `hsp_plan`='$hsp_plan', `hcs_plan`='$hcs_plan' ";
      if (mysqli_query($db, $sql)) {
                    echo "";
               } else {
                        echo "Error: " . $sql . " " . mysqli_error($db);
               }

这是我显示结果的地方,并且工作完美,直到我尝试更新。请参阅以下内容。

  echo 
   "<tr>
   <td>$id_ai</td>
   <td>$name</td>  
   <td>$age</td>
   <td>$agender</td>
   <td><font size=2 color='#DAA520'><b><u>$flex</u></b></font></td>        
   <td align=center><font size=2 color='green'>$hsp_price<br /><a    href=#>$hsp_plan</a></font>

   <form action='hsp.php' method='POST' >
    <select onchange='this.form.submit()'' name='hs' class='form-control'>
        <option name='hs' value='hsp0'>chg</option>
        <option name='hs' value='hsp0'>x</option>
        <option name='hs' value='hsp5012'>5012</option>
        <option name='hs' value='hsp5013'>5013</option>
        <option name='hs' value='hsp5021'>5021</option>
        <option name='hs' value='hsp5022'>5022</option>
        <option name='hs' value='hsp5023'>5023</option>
        <option name='hs' value='hsp5031'>5031</option>
        <option name='hs' value='hsp5032'>5032</option>
        <option name='hs' value='hsp5033'>5033</option>
    </select>
  </form>
 </td>

   </tr>";
  }

  echo "</tbody></table></div>"; 


  /* close statement*/
  $stmt->close();   

  }
  ?>

这是HSP.PHP的瓶颈 - 请注意上面的Form action =&#39; hsp.php ...下面是代码。只更新循环中的最后一条记录。

hsp.php

  <?php
  session_start();

 $db = new mysqli('localhost', 'my_user', 'my_password', 'my_db');

  $_SESSION['hs'] = $_POST['hs'];
  $_SESSION['id_ai'];

  $hs = $_SESSION['hs'];
  $id_ai = $_SESSION['id_ai'];

  $hs = mysqli_real_escape_string($db, $_SESSION['hs']);
  $id_ai = mysqli_real_escape_string($db, $_SESSION['id_ai']);

  $sql = "UPDATE quotes SET hsp_plan='$hs' where id_ai = '$id_ai' ";
               if ($db->query($sql) === TRUE) {
          header("Location: index.php");
  }
  else {
     echo "Error updating record: " . $db->error;
   }         
 ?>

Result Page

1 个答案:

答案 0 :(得分:0)

编辑: 如果我正确理解表的每一行都是一个具有相同名称的表单,则每个表单都有一个输入具有相同的输入名称,并且您希望进行更改并仅更新与用户更改的行对应的数据库行,您可以尝试使用<input type='hidden' name='row_id' value='$row_id'>

原件: 你有几个问题。我注意到的主要问题是你的表单提交给hsp.php但是hsp.php似乎没有设置为给客户端一个视图。

我是否理解您希望客户端在完成后通过进行选择来查看同一个表?您的更新代码可以在页面显示代码之前,但包含在if语句中,如if(isset($_POST['hs'])或其他内容。

如果你让我知道最重要的目标是什么,那么我可以通过更好的方式来完成它。你的方式有点混乱,人们很难跟随。