PDO使用$_POST变量执行问题


PDO Execute Issue with $_POST Variables

当我试图使用$_POST变量将某些内容插入数据库时,遇到了麻烦。

目前我就是这样设置的。当我把这些变量传递给它时,它就起作用了。请注意,在工作示例中,我将所有内容都设置为1。

$video_id = 1;
$user_id = 1;
$session_id = 1;
$user_rating = 1;
$conn = new PDO("mysql:host=$hostname;dbname=db_name", $username, $password);
    $q = $conn->prepare('INSERT INTO video_rating (rating, video_id, user_id, sessionid) VALUES (?, ?, ?, ?)');
$q->execute(array($user_rating, $video_id, $user_id, $user_rating));

但是,当我使用POST变量时

$video_id = $_POST['video_id'];
$user_id = $_POST['user_id'];
$session_id = $_POST['session_id'];
$user_rating = $_POST['user_rating'];

并运行相同的PDO执行,它不起作用。

我的表格是这样的。

<form id="rate-form" method="post" enctype="multipart/form-data">
<input class="auto-submit-star" type="radio" name="user-rating" value="1" title="Very poor"/>
<input class="auto-submit-star" type="radio" name="user-rating" value="2" title="Poor"/>
<input class="auto-submit-star" type="radio" name="user-rating" value="3" title="OK"/>
<input class="auto-submit-star" type="radio" name="user-rating" value="4" title="Good"/>
<input class="auto-submit-star" type="radio" name="user-rating" value="5" title="Very Good"/>
<span id="hover-test" style="margin:0 0 0 15px;" class="rate-text"></span>
<input type="hidden" name="video_id" value="251"/>
<input type="hidden" name="user_id" value="3"/>
<input type="hidden" name="session_id" value="1"/>
<input type="hidden" name="rate_form" />  
</form>

你能看到我可能忽略的东西吗?为什么它不起作用。

您的SQL正在寻找:

 $user_rating = $_POST['user_rating'];

您的HTML包括:

 <input class="auto-submit-star" type="radio" name="user-rating" ...

我认为其中一个是打字错误——当生成SQL时,$user_rating显示为NULL,并且您的表不允许在该字段中有NULL条目。