php обновляет динамические строки sql через форму

0

Моя цель - получить динамический список строк SQL и отредактировать каждый элемент в списке на той же странице с помощью POST (не требуется сразу нескольких изменений). Может ли это быть достигнуто на той же странице? Я сделал сценарий ниже, который отображает все так, как я хочу, однако оператор switch не подходит для purpouse.

Я знаю, что этот код может не быть лучшей практикой (не говоря уже о безопасности). Извините за негибкость, но мне не разрешено использовать что-либо другое, кроме PHP/HTML

Код:

<?php
if ($result->num_rows > 0) {
// output data of each row
while($row = $result->fetch_assoc()) {
    echo '<tr> <td class="tg">' .$row["id"]. '</td>' . "\n";
    echo '<td class="tg"> <form action= "" method="post"> <input type="text" name="voornaam"      value="'.$row["voornaam"].'" style="width:100px"> <input name="submit" type ="submit"  value="Aanpassen"><br/><br/>' . '</td>' . "\n";
    echo '<td class="tg"> <form action= "" method="post"> <input type="text" name="voornaam" value="'.$row["achternaam"].'" style="width:100px"> <input name="submit" type ="submit"  value="Aanpassen"><br/><br/>' . '</td>' . "\n"; 
    echo '<td class="tg"> <form action= "" method="post"> <input type="text" name="voornaam" value="'.$row["omschrijving"].'" style="width:500px"> <input name="submit" type ="submit"  value="Aanpassen"><br/><br/>' . '</td> </tr>' . "\n";
}
} else {
echo "0 resultaten";
}
switch(!empty($_POST))
{
case !empty($_POST[$row["voornaam"]]):
     // update SQL query 'firstname' here
    break;

}
$conn->close();
?>
Теги:
mysqli

3 ответа

0
Лучший ответ

Таким образом, вы действительно видите, что вы редактируете, и это более чисто.

// PDO DB conecction (secure way)
    try {
        $con = new PDO("mysql:host={$host};dbname={$db_name}", $username, $password);
        $con->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

        }catch(PDOException $exception){ //to handle connection error
        echo "Connection error: " . $exception->getMessage();
        }

if isset($_POST["voornaam"]){
 $stmt = $con->prepare(" QUERY");
        $stmt->execute();
echo "YEAH you did it";
} else {
stmt = $con->prepare(" QUERY");
        $stmt->execute();
        $rows = $stmt->fetchAll();

    foreach ($rows as $rs)
        {
            $voornaam = $rs["voornaam"]
    $achternaam = $rs["achternaam"]
    $omschrijving = $rs["omschrijving"]
            }
}

    // Just an example
    echo '<form action= "" method="post"> <input type="text" name="voornaam"      value="'. $voornaam .'" style="width:100px"><input name="submit" type ="submit"  value="Submit"><br/><br/>';

Значение также является входным, поэтому в конце может быть только одна кнопка "Отправить", потому что все остальные данные будут перезаписаны сами по себе.

  • 0
    Спасибо Lixi, работал как шарм.
0
<?php
if ($result->num_rows > 0) 
{
    // output data of each row
        while($row = $result->fetch_assoc()) 
        {
            echo '<tr> <td class="tg">' .$row["id"]. '</td>' . "\n";
            echo '<td class="tg"> <form action= "" method="post"> <input type="text" name="voornaam"      value="'.$row["voornaam"].'" style="width:100px"> <input name="submit" type ="submit"  value="Aanpassen"><br/><br/>' . '</td>' . "\n";
            echo '<td class="tg"> <form action= "" method="post"> <input type="text" name="voornaam" value="'.$row["achternaam"].'" style="width:100px"> <input name="submit" type ="submit"  value="Aanpassen"><br/><br/>' . '</td>' . "\n"; 
            echo '<td class="tg"> <form action= "" method="post"> <input type="text" name="voornaam" value="'.$row["omschrijving"].'" style="width:500px"> <input name="submit" type ="submit"  value="Aanpassen"><br/><br/>' . '</td> </tr>' . "\n";
        }
}
else 
{
    echo "0 resultaten";
}


if( isset( $_POST[$row["voornaam"]] ) && !empty( $_POST[$row["voornaam"]] ) )
{
    // update SQL query 'firstname' here
}
    $conn->close();
?>
0

В вашем коммутаторе вы отправляете !empty($_POST) поэтому boolean (true или false), поэтому уникальными случаями будут: True или False...

Лучше, если вы измените свой переключатель на:

if(isset($_POST[$row["voornaam"]]) && !empty($_POST[$row["voornaam"]])){
  // update SQL query 'firstname' here
}

Ещё вопросы

Сообщество Overcoder
Наверх
Меню