doushui3061 2015-10-27 10:57
浏览 19
已采纳

更新和删除时不显示错误

I have those codes that help to update and delete a row from a table:

html:

<table class="imagetable" cellpadding="3" cellspacing="1" width="400px" border="1">
    <th>ID</th>
    <th>Name</th>
    <th>Informations</th>
    <th>Actions</th>
    <tr>
        <td><input type="text" name="id" value="<?php echo $rows['id'] ?>"/></td>
        <td><input type="text" name="med_name" value="<?php echo $rows['med_name'] ?>"/></td>
        <td><input type="text" name="info" value="<?php echo $rows['info']?>"/></td>
        <td>
            <form action="update_del.php" method="post">
                <input class="imgClass_update" type="submit" name="submit1" value="" />
                <input class="imgClass_dell" type="submit" name="submit2" value=""/>
            </form>
        </td>
    </tr>
    <tr>

PHP:

<?php
require_once('../include/global.php');
$id=$_POST['id'];
if(isset($_POST['submit1']))
{
    $name=$_POST['med_name'];
    $info=$_POST['info'];

    $sql = "UPDATE med SET med_name='$name', 
                            info='$info' 
                            WHERE id='$id'";
    $result=mysqli_query($con,$sql) or die('Unable to execute query. '. mysqli_error($con)); 

    if($result){
        header("location:med.php"); 
    }
    else
    {
        header("location:update_false.php"); 

    }
}
if(isset($_POST['submit2']))
{
    $sql = "DELETE FROM med WHERE id='$id'";
    $result=mysqli_query($con,$sql) or die('Unable to execute query. '. mysqli_error($con));
    if(mysqli_affected_rows($con) == 1)
    {
        header("location:med.php"); 
    }
    else
    {
        header("location:update_false.php"); 

    }
}
?>

Nothing is updated nor deleted. And no errors are shown. If someone could help me, I think the problem is too easy but can't see it where.

  • 写回答

2条回答 默认 最新

  • dozr162106 2015-10-27 10:59
    关注

    You are placing <form> tag at wrong place.

    Therefore, your other elements: id, med_name and info are not children of form.

    And they are not getting posted.

    You should start <form> before table and end after table.

    Corrected Code:

    <form action="update_del.php" method="post">
    <table class="imagetable" cellpadding="3" cellspacing="1" width="400px" border="1">
    <tr>
    <th>ID</th>
    <th>Name</th>
    <th>Informations</th>
    <th>Actions</th>
    </tr>
    <tr>
    <td><input type="text" name="id" value="<?php echo $rows['id'] ?>"/></td>
    <td><input type="text" name="med_name" value="<?php echo $rows['med_name'] ?>"/></td>
    <td><input type="text" name="info" value="<?php echo $rows['info']?>"/></td>
    <td>
    <input class="imgClass_update" type="submit" name="submit1" value="Update" />
    <input class="imgClass_dell" type="submit" name="submit2" value="Delete"/>        
    </td>
    </tr>
    </table>
    </form>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能