我有这个代码,从数据库中获取类别并在下拉菜单中显示它们。现在,我想做什么,是什么时候选择了什么,按钮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 - 我知道这很容易注射,你不需要告诉我,请回答这个问题:)
答案 0 :(得分:1)
您很可能只需要更改此行,并将value
作为类别主键,如id
或其他任何名称。
echo "<option value='{$row['id']}'>{$row['category']}</option>";
否则提交后你必须运行一个mysql查询,通过搜索id
category='$newCategory'