回调可编辑PHP不起作用

时间:2015-01-10 18:39:22

标签: php mysql ajax

我创建了一个表格,我可以在td内编辑它并且效果非常好。我编辑了产品名称,它在我的网页上成功更改,但它没有更新到数据库。

我的数据库是这样的:

以下是td内编辑的代码。

$results = $mysqli->query("SELECT * FROM productList");
while($row = $results->fetch_assoc()) {
    <td> <span class="edit" id="'.$row['ID'].'"> '.$row['name'].' </span> </td>
}

对于可编辑,我必须使用AJAX来调用该值。像这样:

jQuery(document).ready(function() {  
    $.fn.editable.defaults.mode = 'popup';
    $('.edit').editable();     
    $(document).on('click','.editable-submit',function(){
        var x = $(this).closest('td').children('span').attr('id');
        var y = $('.input-sm').val();
        var z = $(this).closest('td').children('span');
        $.ajax({
            url: "edit.php?id="+x+"&data="+y,
            type: 'GET',
            success: function(s){
                if(s == 'status'){
                $(z).html(y);}
                if(s == 'error') {
                alert('Error Processing your Request!');}
            },
            error: function(e){
                alert('Error Processing your Request!!');
            }
        });
    });
});

在AJAX之后,我必须将网址调用edit.phpedit.php的代码如下:

$mysqli = new mysqli('localhost','root','root','database_name');
if ($mysqli->connect_error) {
    die('Error : ('. $mysqli->connect_errno .') '. $mysqli->connect_error);
}

if($_GET['id'] and $_GET['name'])
{
    $id = $_GET['id'];
    $name = $_GET['name'];
    if ($mysqli->query("UPDATE productList SET name='$name' WHERE ID='$id'"));
    $mysqli->close();
    echo 'success';
}

我尝试在phpmyadmin中手动更新,它在那里工作得非常好。但不是在这里。它现在应该正常工作。我错过了什么吗?

1 个答案:

答案 0 :(得分:0)

需要更新您的代码,如下所示。如果文件正常,您可以直接调用edit.php?id=..&name=..进行调试。

jQuery的:

$.ajax({
            url: "edit.php?id="+x+"&name="+y,
            type: 'GET',
            success: function(s){
                alert(s) ;
                if(s == 'status'){
                   $(z).html(y);
                }                    
            },
            error: function(e){
                alert(e.status);
            }
        });

PHP:

if($_GET['id'] && $_GET['name']) // this is not SQL! so and will not work!
{
    $id = $_GET['id'];
    $name = $_GET['name'];
    if ($result = $mysqli->query("UPDATE productList SET name='".$name."' WHERE ID='". $id."'")){

       $mysqli->close(); 
       echo 'success';
    }else{
        echo mysqli->error;
    }


}

READ Some MYSQLI DOC