簡體   English   中英

使用復選框將多行插入MySQL

[英]Inserting multiple rows into MySQL with checkbox

下面是我的代碼。 我有兩個MySQL數據庫表,一個是“成員”,另一個是“參與者”。 我想將表“ member”中的數據顯示到我的本地主機頁面上,並且做到了。 但是,我無法通過使用復選框將多個“成員”數據行插入數據庫表“參與者”。 我被困住了。 任何幫助深表感謝。

<?php
try {
    $con = new PDO("mysql:host=localhost;dbname=kgruum member", "root", "");
    $sql = $con->query("SELECT * FROM member");
    echo "<table class='info' align='center' border='1'>";
    echo "<tr><td width='10'></td>
        <td width='10'><b>ID</b></td>
        <td width='500'><b>Name</b></td>
        <td width='50'><b>Handicap</b></td><tr>";

    foreach($sql as $row) {
        $ID = $row["ID"];
        $Name = $row["Name"];
        $Handicap = $row["Handicap"];
        echo "<tr>
            <td><form method='POST' action='Add participant.php'><input type='checkbox' name='insert[]' value='$ID'></td>
            <td>$ID</td>
            <td>$Name</td>
            <td>$Handicap</td><tr>";
    }

    echo"</table><div align='center'><input type='image' value='submit' src='add selected button.png' alt='submit Button' onmouseover='this.src='pink add selected button.png'' onmouseout='this.src='add selected button.png'' name='add_btn' id='add_btn'></div><br></form>";


    if(isset($_POST['add_btn'])) {
        if(!empty($_POST['insert'])) {
            foreach($_POST['insert'] as $check) {
                $st=$con->prepare("INSERT INTO participants(ID,Name,Handicap) VALUES('$ID','$Name','$Handicap')");
                $insert->bindParam('ID',$ID);
                $insert->bindParam('Name',$Name);
                $insert->bindParam('Handicap',$Handicap);
                $st->execute();
                }
           echo "<script type='text/javascript'>
               alert('Successful Insert ! ');
               window.location.href = 'Add participant.php';
               </script>";
         } else {
           echo "<script type='text/javascript'>alert('You didn't choose which user you want to insert ! ')</script>";
      }
    }
} catch(PDOException $e) {
    echo "error".$e->getMessage();
}
?>

您沒有將$ Name和$ Handicap值存儲在insert []數組中,僅存儲了$ ID值。

要解決,請執行以下操作:

<input type='checkbox' name='insert[]' value='$ID|$Name|$Handicap'>

然后:

foreach($_POST['insert'] as $check) {
  $values = explode('|', $check);
  $ID = $values[0];
  $Name = $values[1];
  $Handicap = $values[2];
  //The rest of your SQL code goes here as you have it...
  $check = ''; 
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM