繁体   English   中英

使用表单更新MySQL数据库

[英]Update a MySQL Database with a Form

我正在尝试创建一种表单,允许用户从下拉框中选择一个字段,然后更改当前写在该字段中的内容。

我当前的代码允许我查看下拉列表,选择要更改的字段,然后在框中输入新文本。 但是,当我单击更新时,什么也没有发生。

<?php 
mysql_connect("", "", "") or die(mysql_error());
mysql_select_db("") or die(mysql_error()); 

$query = "SELECT * FROM news_updates";
$result=mysql_query($query) or die("Query Failed : ".mysql_error());
$i=0;
while($rows=mysql_fetch_array($result))
{
$roll[$i]=$rows['Text'];
$i++;
}
$total_elmt=count($roll);
?>
---------------------------------------------------------Now I have the form 
 <form method="POST" action="">
 Select the news post to Update: <select name="sel">
<option>Select</option>
<?php 
for($j=0;$j<$total_elmt;$j++)
{
?><option><?php 
echo $roll[$j];
?></option><?php
}
?>
</select><br />
Text Field: <input name="username" type="text" /><br />
<input name="submit" type="submit" value="Update"/><br />
<input name="reset" type="reset" value="Reset"/>
</form>
-----------------------------------------------Now I have the update php
<?php
if(isset($_POST['submit']))
{
$username=$_POST['username'];
$query2 = "UPDATE news_updates SET username='$username' WHERE rollno='$value'";
$result2=mysql_query($query2) or die("Query Failed : ".mysql_error());
echo "Successfully Updated";
}
?>

好吧,您似乎缺少$value部分。 对于最后一部分,应该执行以下操作:

<?php
if(isset($_POST['submit']))
  {
    $username = mysql_real_escape_string($_POST['username']);
    $value = mysql_real_escape_string($_POST['sel']);
    $query2 = "UPDATE news_updates SET username='$username' WHERE rollno='$value'";
    echo $query2; //For test, to see what is generated, and sent to database
    $result2=mysql_query($query2) or die("Query Failed : ".mysql_error());
    echo "Successfully Updated";
}
?>

另外,不应该使用不推荐使用的mysql_ *函数。 您应该切换到mysqli或PDO。

你需要改变这个

<?php 
for($j=0;$j<$total_elmt;$j++)
{
?><option><?php 
echo $roll[$j];
?></option><?php
}

对此

<?php 
for($j=0;$j<$total_elmt;$j++)
{
?><option value="<?php echo $roll[$j];?>"> <?php echo $roll[$j];?></option> <?php
}

而且您还需要从中更改更新查询

$query2 = "UPDATE news_updates SET username='$username' WHERE rollno='$value'";

对此

$query2 = "UPDATE news_updates SET username='$username' WHERE rollno='".$_POST['sel']."'";

注意:这里我假设$_POST['sel']具有用户从下拉菜单中选择的值,因为我找不到与$value相对应的任何内容

首先,尝试为您的选项添加一个值,如下所示:

for($j=0;$j<$total_elmt;$j++)
{
?>
    <option value="<?php echo $roll['id']; ?>"><?php echo $roll['option_name']; ?></option>
<?php
}

然后,当您解析文件时,如下所示:

$value = $_POST['sel']; // add any desired security here

那应该为你做

暂无
暂无

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

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