我创建了一个表格,我可以在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.php
。 edit.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中手动更新,它在那里工作得非常好。但不是在这里。它现在应该正常工作。我错过了什么吗?
答案 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;
}
}