【发布时间】:2015-06-19 11:34:58
【问题描述】:
我有下面的代码,但我不知道为什么它不起作用。问题是我可以用它插入帖子,但是当我尝试更新帖子时,它会创建一个新页面而不是更新。
我试图从if(isset($_POST['id']) != 'null') 中删除isset 并且更新工作正常,但是插入不再工作。
知道我的代码有什么问题吗?谢谢。
<?php
if(isset($_POST['submitted']) == 1)
{
$title = mysqli_real_escape_string($dbc, $_POST['title']);
$header = mysqli_real_escape_string($dbc, $_POST['header']);
$body = mysqli_real_escape_string($dbc, $_POST['body']);
if(isset($_POST['id']) != 'null')
{
$q = "UPDATE pages SET user = $_POST[user], title = '$title', header = '$header', body = '$body' WHERE id = $_GET[id]";
}
else
{
$q = "INSERT INTO pages (user, title, header, body) VALUES ($_POST[user], '$title', '$header', '$body')";
}
$r = mysqli_query($dbc, $q);
if($r)
{
$message = '<p>Page was added!</p>';
}
else
{
$message = '<p>Page could not be added because:</p>'.mysqli_error($dbc);
$message .= '<p>'.$q.'</p>';
}
}
?>
【问题讨论】:
-
请为这两种情况创建一个 var_dump($_POST) 并将其添加到问题中。
-
isset返回一个布尔值(因此为 TRUE 或 FALSE),因此isset(..) != 'null'绝对没有意义。为什么不直接使用if (isset(..))? -
isset($_POST['id']) != 'null'这没什么意义,试试去掉!= 'null'
标签: php mysql mysqli content-management-system sql-insert