$ _POST合并数组并仅存储在一列中

时间:2013-01-05 18:46:41

标签: php ajax database

我有一个表单发布到php处理程序,它将表单中的数据保存到数据库中。 我不认为保存功能是问题。我认为$_POST合并表单数据存在问题。当我查看sql表时,数据存在,但所有值都出现在一列中,因此变量正在从表单中正确传递。

这是我的代码:

$name = isset($_POST['name']) ? $_POST['name'] : '';
$email = isset($_POST['email']) ? $_POST['email'] : '';
$com_dis = isset($_POST['comment']) ? $_POST['comment'] : '';
$id = isset($_POST['id']) ? $_POST['id'] : '';

$lowercase = strtolower($email);
$image = md5( $lowercase );

try{
    $conn = new PDO( DB_DSN, DB_USERNAME, DB_PASSWORD );
    $sql = 'INSERT INTO comments ( com_name, com_email, com_dis, post_id_fk ) VALUES ( :name, :email, :com_dis, :id )';
    $st = $conn->prepare ( $sql );
$st->bindValue( ":name", $name, PDO::PARAM_STR );
    $st->bindValue( ":email", $email, PDO::PARAM_STR );
    $st->bindValue( ":com_dis", $com_dis, PDO::PARAM_STR );
    $st->bindValue( ":id", $id, PDO::PARAM_INT );
    $st->execute();
    $conn = null;
}catch(PDOException $e ){
    echo "QUERY FAILED" . $e->getMessage();
};

如果我对所有变量使用$id = $_POST['id'],则会抛出一个未识别的索引错误。当我打印$_POST时,它会显示一个数组,其中数组名为name,内容只是其余的变量,这些变量与表中存储的数据相同。

如何正确保存数据或停止$_POST合并变量以便它们?保存在正确的列中?

这是我的表格:

<form action="#" method="post">
    <input type="hidden" name="id" id="id" value="<?php echo $id; ?>"/><br />
    <span class="titles">Name</span><span class="star">*</span><br /><input type="text" name="name" id="name"/><br />

    <span class="titles">Email</span><span class="star">*</span><br /><input type="text" name="email" id="email"/><br />

    Comment<br /><textarea name="comment" id="comment"></textarea><br />

    <input type="submit" class="submit" value=" Submit Comment " />
</form>

表单通过AJAX传递:

$(function() {

    $(".submit").click(function() {

        name = $("#name").val();
        var email = $("#email").val();
        var comment = $("#comment").val();
        var id = $("#id").val();
        var dataString = 'name='+ name + 'email=' + email + 'comment=' + comment + 'id=' + id;

        if(name=='' || email=='' || comment==''){
            alert('Please Give Valid Details');
        }

        else{
            $("#flash").show();
            $("#flash").fadeIn(400).html('<img src="ajax-loader.gif" align="absmiddle">&nbsp;<span class="loading">Loading Comment...</span>');

            $.ajax({
                type: "POST",
                url: "commentajax.php",
                data: dataString,
                cache: false,
                success: function(html){

                    $("ol#update").append(html);
                    $("ol#update li:last").fadeIn("slow");
                    document.getElementById('email').value='';
                    document.getElementById('name').value='';
                    document.getElementById('comment').value='';
                    $("#name").focus();

                    $("#flash").hide();
            }
        });
    }
return false;
});

1 个答案:

答案 0 :(得分:3)

您需要连接数据字符串:

var dataString = 'name='+ name + 'email=' + email + 'comment=' + comment + 'id=' + id;

应该是

var dataString = 'name='+ name + '&email=' + email + '&comment=' + comment + '&id=' + id;