将动态信息插入数据库(动态下拉菜单)

时间:2013-09-13 14:30:26

标签: php mysql

我有这个代码,从数据库中获取类别并在下拉菜单中显示它们。现在,我想做什么,是什么时候选择了什么,按钮isset,获取该类别的ID(表:categories,行category_id)然后将其提交到(表格中) :posts,行category_id)。我不知道如何获取下拉列表中所选类别的ID。谢谢。
$db变量是数据库连接。

这是我到目前为止所得到的。这是向数据库提交数据:

include('../includes/db_connect.php');
if(isset($_POST['submit'])){
    $newTitle = $_POST['newTitle'];
    $newPost = $_POST['newPost'];
    $newCategory = $_POST['newCategory'];
    $my_date = date("Y-m-d H:i:s");
    if(!empty($newPost))
        if(!empty($newTitle)){
    $sql="INSERT INTO posts  (title, body, category_id)
VALUES('$newTitle', '$newPost', '$newCategory')";
    $query = $db->query($sql);
    if($query){
            echo "Post entered to database";
        }else{
            echo "Error Submitting the data";
        }
    }
}

这是选择:

<textarea name="newPost" cols="176" rows="25"/></textarea><br>
<select name=""="newCategory" id="newCategory">
    <option value="0">Select category</option>
<?php
    $result = mysqli_query($db, "SELECT * FROM categories");
    if ( $result ) {
        while( $row = mysqli_fetch_array($result, MYSQLI_ASSOC) ) {

            echo '<option value="' . $row['category'] . '">' . $row['category'] . '</option>';

        }
    } else {
        echo 'Couldn\'t fetch Categories from MySQL.';
    }
?>

Ps - 我知道这很容易注射,你不需要告诉我,请回答这个问题:)

1 个答案:

答案 0 :(得分:1)

您很可能只需要更改此行,并将value作为类别主键,如id或其他任何名称。

echo "<option value='{$row['id']}'>{$row['category']}</option>";

否则提交后你必须运行一个mysql查询,通过搜索id

的位置来查找category='$newCategory'