繁体   English   中英

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

[英]How to change Single row Array Variable inside While Loop and use new result to Update Database Table

END处的HTML TABLE结果图片

请在下面完成代码-订单。 注意-我可以轻松更改所有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的瓶颈-在表格action ='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;
   }         
 ?>

结果页

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

原文:您遇到了一些问题。 我注意到的主要问题是您的表单提交给了hsp.php,但是hsp.php并未设置为向客户端提供视图。

我是否了解您希望客户端在完成选择后就看到相同的表? 您的更新代码可以在页面显示代码之前,但是包装在if语句中,例如if(isset($_POST['hs'])

如果您让我知道总体目标是什么,那么我可能可以带您通过一种更好的方法来实现目标。 您的方式有些杂乱无章,将使人们难以遵循。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM