只有删除选项不起作用 PHP CRUD
only Delete option is not working PHP CRUD
我一直在研究基本的 PHP CRUD。我正在使用基于 PHP, AJAX, MySQL
的 CRUD。
我有 Add / Update / Delete / GetResults / Search
这样的功能。除了 Delete
选项外,一切正常。我尝试了很多方法来解决这个问题,但似乎无法在代码中找到确切的错误或错误。这是我用于 CRUD 操作的代码。
exam_packages.php
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Add / Update / Delete Exam Packages</title>
<link rel="stylesheet" href="css/bootstrap.min.css" type="text/css" media="all">
<link href="css/jquery.bootgrid.css" rel="stylesheet" />
<script src="js/jquery-1.11.1.min.js"></script>
<script src="js/bootstrap.min.js"></script>
<script src="js/jquery.bootgrid.min.js"></script>
</head>
<body>
<div class="container">
<div class="">
<h1 style="text-align: center;">Add / Update / Delete Exam Packages</h1>
<div class="col-sm-12">
<div class="well clearfix">
<div class="pull-right"><button type="button" class="btn btn-xs btn-primary" id="command-add" data-row-id="0">
<span class="glyphicon glyphicon-plus"></span> Add New Exam Package</button></div></div>
<table id="exam_package_grid" class="table table-condensed table-hover table-striped" width="60%" cellspacing="0" data-toggle="bootgrid">
<thead>
<tr>
<th data-column-id="pkg_id" data-type="numeric" data-identifier="true">Package ID</th>
<th data-column-id="test_quantity">Test Quantity</th>
<th data-column-id="price">Price</th>
<th data-column-id="commands" data-formatter="commands" data-sortable="false">Commands</th>
</tr>
</thead>
</table>
</div>
</div>
</div>
<div id="add_model" class="modal fade">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h4 class="modal-title">Add New Exam Package</h4>
</div>
<div class="modal-body">
<form method="post" id="frm_add">
<input type="hidden" value="add" name="action" id="action">
<div class="form-group">
<label for="test_quantity" class="control-label">Test Quantity:</label>
<input type="text" class="form-control" id="test_quantity" name="test_quantity"/>
</div>
<div class="form-group">
<label for="price" class="control-label">Price:</label>
<input type="text" class="form-control" id="price" name="price"/>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
<button type="button" id="btn_add" class="btn btn-primary">Save</button>
</div>
</form>
</div>
</div>
</div>
<div id="edit_model" class="modal fade">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h4 class="modal-title">Edit Exam Package</h4>
</div>
<div class="modal-body">
<form method="post" id="frm_edit">
<input type="hidden" value="edit" name="action" id="action">
<input type="hidden" value="0" name="edit_pkg_id" id="edit_pkg_id">
<div class="form-group">
<label for="test_quantity" class="control-label">Test Quantity:</label>
<input type="text" class="form-control" id="edit_test_quantity" name="edit_test_quantity"/>
</div>
<div class="form-group">
<label for="price" class="control-label">Price:</label>
<input type="text" class="form-control" id="edit_price" name="edit_price"/>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
<button type="button" id="btn_edit" class="btn btn-primary">Save</button>
</div>
</form>
</div>
</div>
</div>
</body>
</html>
<script type="text/javascript">
$( document ).ready(function() {
var grid = $("#exam_package_grid").bootgrid({
ajax: true,
rowSelect: true,
post: function ()
{
/* To accumulate custom parameter with the request object */
return {
id: "b0df282a-0d67-40e5-8558-c9e93b7befed"
};
},
url: "exam_package_response.php",
formatters: {
"commands": function(column, row)
{
return "<button type=\"button\" class=\"btn btn-xs btn-default command-edit\" data-row-id=\"" + row.pkg_id + "\"><span class=\"glyphicon glyphicon-edit\"></span></button> " +
"<button type=\"button\" class=\"btn btn-xs btn-default command-delete\" data-row-id=\"" + row.pkg_id + "\"><span class=\"glyphicon glyphicon-trash\"></span></button>";
}
}
}).on("loaded.rs.jquery.bootgrid", function()
{
/* Executes after data is loaded and rendered */
grid.find(".command-edit").on("click", function(e)
{
//alert("You pressed edit on row: " + $(this).data("row-id"));
var ele =$(this).parent();
var g_pkg_id = $(this).parent().siblings(':first').html();
//console.log(grid.data());//
$('#edit_model').modal('show');
if($(this).data("row-id") >0) {
// collect the data
$('#edit_pkg_id').val(ele.siblings(':first').html()); // in case we're changing the key
$('#edit_test_quantity').val(ele.siblings(':nth-of-type(2)').html());
$('#edit_price').val(ele.siblings(':nth-of-type(3)').html());
} else {
alert('No row selected! First select row, then click edit button');
}
}).end().find(".command-delete").on("click", function(e)
{
var conf = confirm('Delete No.' + $(this).data("row-id") + ' package?');
alert(conf);
if(conf==true){
// console.log($(this).data("row-id"));
$.post('exam_package_response.php', { id: $(this).data("row-id"), action:'delete'}, function()
{
$("#exam_package_grid").bootgrid('reload');
});
$(this).parent('tr').remove();
$("#exam_package_grid").bootgrid('remove', $(this).data("row-id"))
}
});
});
function ajaxAction(action) {
data = $("#frm_"+action).serializeArray();
$.ajax({
type: "POST",
url: "exam_package_response.php",
data: data,
dataType: "json",
success: function(response)
{
$('#'+action+'_model').modal('hide');
$("#exam_package_grid").bootgrid('reload');
}
});
}
$( "#command-add" ).click(function() {
$('#add_model').modal('show');
});
$( "#btn_add" ).click(function() {
ajaxAction('add');
});
$( "#btn_edit" ).click(function() {
ajaxAction('edit');
});
});
</script>
exam_package_resposnse.php
<?php
//include connection file
include_once("db_connection_mysqli.php");
$db = new dbObj();
$connString = $db->getConnstring();
$params = $_REQUEST;
// console.log($params);
// echo '<script>alert("aaaaaaaaaa");</script>';
$action = isset($params['action']) != '' ? $params['action'] : '';
$empCls = new ExamPackage($connString);
switch($action) {
case 'add':
$empCls->insertExamPackage($params);
break;
case 'edit':
$empCls->updateExamPackage($params);
break;
case 'delete':
$empCls->deleteExamPackage($params);
break;
default:
$empCls->getExamPackages($params);
return;
}
class ExamPackage {
protected $conn;
protected $data = array();
function __construct($connString) {
$this->conn = $connString;
}
public function getExamPackages($params) {
$this->data = $this->getRecords($params);
echo json_encode($this->data);
}
function insertExamPackage($params) {
$data = array();;
$sql = "INSERT INTO `tblExamPackages` (test_quantity, price) VALUES('" . $params["test_quantity"] . "', '" . $params["price"] . "'); ";
echo $result = mysqli_query($this->conn, $sql) or die("error to insert package data");
}
function getRecords($params) {
$rp = isset($params['rowCount']) ? $params['rowCount'] : 10;
if (isset($params['current'])) { $page = $params['current']; } else { $page=1; };
$start_from = ($page-1) * $rp;
$sql = $sqlRec = $sqlTot = $where = '';
if( !empty($params['searchPhrase']) ) {
$where .=" WHERE ";
$where .=" (test_quantity LIKE '%".$params['searchPhrase']."%' ";
$where .=" OR price = '".$params['searchPhrase']."' )";
}
if( !empty($params['sort']) ) {
$where .=" ORDER By ".key($params['sort']) .' '.current($params['sort'])." ";
}
// getting total number records without any search
$sql = "SELECT * FROM `tblExamPackages` ";
$sqlTot .= $sql;
$sqlRec .= $sql;
//concatenate search sql if value exist
if(isset($where) && $where != '') {
$sqlTot .= $where;
$sqlRec .= $where;
}
if ($rp!=-1)
$sqlRec .= " LIMIT ". $start_from .",".$rp;
$qtot = mysqli_query($this->conn, $sqlTot) or die("error to fetch tot package data");
$queryRecords = mysqli_query($this->conn, $sqlRec) or die("error to fetch package data");
while( $row = mysqli_fetch_assoc($queryRecords) ) {
$data[] = $row;
}
$json_data = array(
"current" => intval($params['current']),
"rowCount" => 10,
"total" => intval($qtot->num_rows),
"rows" => $data // total data array
);
return $json_data;
}
function updateExamPackage($params) {
$data = array();
//print_R($_POST);die;
$sql = "Update `tblExamPackages` set test_quantity = '" . $params["edit_test_quantity"] . "', price='" . $params["edit_price"]."' WHERE pkg_id='".$_POST["edit_pkg_id"]."'";
echo $result = mysqli_query($this->conn, $sql) or die("error to update package data");
}
function deleteExamPackage($params) {
$data = array();
echo "<script>
var conf = confirm('Delete No.' + $(this).data('row-id') + ' package?');
alert(conf);</script>";
$sql = "delete from `tblExamPackages` WHERE pkg_id'" . $_REQUEST["edit_pkg_id"] . "'";
echo $result = mysqli_query($this->conn, $sql) or die("error to delete package data");
}
}
?>
如果我在这里遗漏了什么,请告诉我。一切正常,除了 Delete
简答:
您的删除查询有语法错误。这在评论中有所暗示...
您还通过尝试在 php class 中使用 JavaScript 来混合服务器端和客户端。这是一个重大错误,需要一些人回过头来回顾基础知识。
长答案:
我发现您正在尝试转向 OOP 编程,并且您正在做一些正确的事情;值得注意的是,将数据库连接注入到您的 crud 对象中。
但有些事情可以做得更好。这里有一些想法——
- Use PDO 而不是 mysqli,并且 使用准备好的语句 。这很可能会消除查询中的语法错误。
- 总是 return json 来自 Ajax 请求的编码数据。我个人总是让 php 脚本响应
return json_encode( ['message'=>$message, 'data'=>$data] );
。然后您 JavaScript 回到浏览器可以决定向用户传达什么。
- 方法应该做一件事。如果该方法变得比屏幕上显示的要大,您可能需要重构。例如,
getRecords()
检查页码、创建查询、获取总数并获取所有记录。这可能应该分解成单独的方法,或者更好的是,创建一个可以注入到查询创建方法中的分页对象。
顺便说一句,为了说明准备好的语句的重要性:如果有人去了 hxxp://yourdomain/exam_package_response.php?action=delete&edit_pkg_id=1+or+1%3D1
怎么办?
答案:您刚刚丢失了此 table 中的所有数据。准备好的语句将防止这种情况。
在
deleteExamPackage($params) function
在第 7 行,在 echo 语句之前,您忘记添加
=
改变这个
`$sql = "delete from `tblExamPackages` WHERE pkg_id'" . $_REQUEST["edit_pkg_id"] . "'";`
到
$sql = `"delete from `tblExamPackages` WHERE pkg_id = '" . $_REQUEST["edit_pkg_id"] . "'";`
在一些小伙伴的指导下,我成功解决了问题。
基本上,我无法从我的 CRUD 网格中删除一行。实际上,我无法正确检测到错误。根据上面的答案和评论,我找到了错误并解决了。
以下是我为使其正常工作所做的更改。
Delete Query had a Syntax error.
我的删除查询有一个小错误。我错过了 =
登录 where
条款。虽然这不是最初的问题,但这是一个需要解决的问题。
Wasn't getting pkg_id
sent from AJAX
to PHP
.
所以核心问题是,我的查询正在执行,但我没有在传递的变量中获得 pkg_id
的值。实际上我没有正确调试它,否则我什至不必在这里 post 它。感谢上面的 Tim Morton 先生,我调试了这个问题。奇怪的是,使用相同的方法,我在 UPDATE
函数中获得了值,但在 DELETE
中却没有。我尝试了一些方法来解决这个问题,但无法解决。
所以我用Cookies来解决问题。解决方法是 Creating Cookie using AJAX and retrieving its value in PHP
。这是我用来执行此操作的代码。我只提到我重写的部分代码。
exam_packages.php
在 $(document).ready(function()
之后写了一个函数来创建 cookie
function createCookie(name, value, days)
{
var expires;
if (days)
{
var date = new Date();
date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
expires = "; expires=" + date.toGMTString();
}
else
{
expires = "";
}
document.cookie = escape(name) + "=" + escape(value) + expires + "; path=/";
}
并将其用作
createCookie("pkg_id", $(this).data("row-id"), "1");
在var conf = confirm('Delete No.' + $(this).data("row-id") + ' package?');
之后
这将创建名为 pkg_id
.
的 Cookie
exam_package_resposnse.php
已访问此文件中的 cookie 值
$pkg_id = $_COOKIE["pkg_id"];
并使用 pkg_id
作为我的 where
子句的参数。
我知道这可能不是解决此问题的正确方法,但这绝对是其中一种方法。我测试了它并且它正在工作。如果有人有更好的方法来做到这一点,请随时分享,因为它可能对其他人和我也有用。 :)
此致
我一直在研究基本的 PHP CRUD。我正在使用基于 PHP, AJAX, MySQL
的 CRUD。
我有 Add / Update / Delete / GetResults / Search
这样的功能。除了 Delete
选项外,一切正常。我尝试了很多方法来解决这个问题,但似乎无法在代码中找到确切的错误或错误。这是我用于 CRUD 操作的代码。
exam_packages.php
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Add / Update / Delete Exam Packages</title>
<link rel="stylesheet" href="css/bootstrap.min.css" type="text/css" media="all">
<link href="css/jquery.bootgrid.css" rel="stylesheet" />
<script src="js/jquery-1.11.1.min.js"></script>
<script src="js/bootstrap.min.js"></script>
<script src="js/jquery.bootgrid.min.js"></script>
</head>
<body>
<div class="container">
<div class="">
<h1 style="text-align: center;">Add / Update / Delete Exam Packages</h1>
<div class="col-sm-12">
<div class="well clearfix">
<div class="pull-right"><button type="button" class="btn btn-xs btn-primary" id="command-add" data-row-id="0">
<span class="glyphicon glyphicon-plus"></span> Add New Exam Package</button></div></div>
<table id="exam_package_grid" class="table table-condensed table-hover table-striped" width="60%" cellspacing="0" data-toggle="bootgrid">
<thead>
<tr>
<th data-column-id="pkg_id" data-type="numeric" data-identifier="true">Package ID</th>
<th data-column-id="test_quantity">Test Quantity</th>
<th data-column-id="price">Price</th>
<th data-column-id="commands" data-formatter="commands" data-sortable="false">Commands</th>
</tr>
</thead>
</table>
</div>
</div>
</div>
<div id="add_model" class="modal fade">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h4 class="modal-title">Add New Exam Package</h4>
</div>
<div class="modal-body">
<form method="post" id="frm_add">
<input type="hidden" value="add" name="action" id="action">
<div class="form-group">
<label for="test_quantity" class="control-label">Test Quantity:</label>
<input type="text" class="form-control" id="test_quantity" name="test_quantity"/>
</div>
<div class="form-group">
<label for="price" class="control-label">Price:</label>
<input type="text" class="form-control" id="price" name="price"/>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
<button type="button" id="btn_add" class="btn btn-primary">Save</button>
</div>
</form>
</div>
</div>
</div>
<div id="edit_model" class="modal fade">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h4 class="modal-title">Edit Exam Package</h4>
</div>
<div class="modal-body">
<form method="post" id="frm_edit">
<input type="hidden" value="edit" name="action" id="action">
<input type="hidden" value="0" name="edit_pkg_id" id="edit_pkg_id">
<div class="form-group">
<label for="test_quantity" class="control-label">Test Quantity:</label>
<input type="text" class="form-control" id="edit_test_quantity" name="edit_test_quantity"/>
</div>
<div class="form-group">
<label for="price" class="control-label">Price:</label>
<input type="text" class="form-control" id="edit_price" name="edit_price"/>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
<button type="button" id="btn_edit" class="btn btn-primary">Save</button>
</div>
</form>
</div>
</div>
</div>
</body>
</html>
<script type="text/javascript">
$( document ).ready(function() {
var grid = $("#exam_package_grid").bootgrid({
ajax: true,
rowSelect: true,
post: function ()
{
/* To accumulate custom parameter with the request object */
return {
id: "b0df282a-0d67-40e5-8558-c9e93b7befed"
};
},
url: "exam_package_response.php",
formatters: {
"commands": function(column, row)
{
return "<button type=\"button\" class=\"btn btn-xs btn-default command-edit\" data-row-id=\"" + row.pkg_id + "\"><span class=\"glyphicon glyphicon-edit\"></span></button> " +
"<button type=\"button\" class=\"btn btn-xs btn-default command-delete\" data-row-id=\"" + row.pkg_id + "\"><span class=\"glyphicon glyphicon-trash\"></span></button>";
}
}
}).on("loaded.rs.jquery.bootgrid", function()
{
/* Executes after data is loaded and rendered */
grid.find(".command-edit").on("click", function(e)
{
//alert("You pressed edit on row: " + $(this).data("row-id"));
var ele =$(this).parent();
var g_pkg_id = $(this).parent().siblings(':first').html();
//console.log(grid.data());//
$('#edit_model').modal('show');
if($(this).data("row-id") >0) {
// collect the data
$('#edit_pkg_id').val(ele.siblings(':first').html()); // in case we're changing the key
$('#edit_test_quantity').val(ele.siblings(':nth-of-type(2)').html());
$('#edit_price').val(ele.siblings(':nth-of-type(3)').html());
} else {
alert('No row selected! First select row, then click edit button');
}
}).end().find(".command-delete").on("click", function(e)
{
var conf = confirm('Delete No.' + $(this).data("row-id") + ' package?');
alert(conf);
if(conf==true){
// console.log($(this).data("row-id"));
$.post('exam_package_response.php', { id: $(this).data("row-id"), action:'delete'}, function()
{
$("#exam_package_grid").bootgrid('reload');
});
$(this).parent('tr').remove();
$("#exam_package_grid").bootgrid('remove', $(this).data("row-id"))
}
});
});
function ajaxAction(action) {
data = $("#frm_"+action).serializeArray();
$.ajax({
type: "POST",
url: "exam_package_response.php",
data: data,
dataType: "json",
success: function(response)
{
$('#'+action+'_model').modal('hide');
$("#exam_package_grid").bootgrid('reload');
}
});
}
$( "#command-add" ).click(function() {
$('#add_model').modal('show');
});
$( "#btn_add" ).click(function() {
ajaxAction('add');
});
$( "#btn_edit" ).click(function() {
ajaxAction('edit');
});
});
</script>
exam_package_resposnse.php
<?php
//include connection file
include_once("db_connection_mysqli.php");
$db = new dbObj();
$connString = $db->getConnstring();
$params = $_REQUEST;
// console.log($params);
// echo '<script>alert("aaaaaaaaaa");</script>';
$action = isset($params['action']) != '' ? $params['action'] : '';
$empCls = new ExamPackage($connString);
switch($action) {
case 'add':
$empCls->insertExamPackage($params);
break;
case 'edit':
$empCls->updateExamPackage($params);
break;
case 'delete':
$empCls->deleteExamPackage($params);
break;
default:
$empCls->getExamPackages($params);
return;
}
class ExamPackage {
protected $conn;
protected $data = array();
function __construct($connString) {
$this->conn = $connString;
}
public function getExamPackages($params) {
$this->data = $this->getRecords($params);
echo json_encode($this->data);
}
function insertExamPackage($params) {
$data = array();;
$sql = "INSERT INTO `tblExamPackages` (test_quantity, price) VALUES('" . $params["test_quantity"] . "', '" . $params["price"] . "'); ";
echo $result = mysqli_query($this->conn, $sql) or die("error to insert package data");
}
function getRecords($params) {
$rp = isset($params['rowCount']) ? $params['rowCount'] : 10;
if (isset($params['current'])) { $page = $params['current']; } else { $page=1; };
$start_from = ($page-1) * $rp;
$sql = $sqlRec = $sqlTot = $where = '';
if( !empty($params['searchPhrase']) ) {
$where .=" WHERE ";
$where .=" (test_quantity LIKE '%".$params['searchPhrase']."%' ";
$where .=" OR price = '".$params['searchPhrase']."' )";
}
if( !empty($params['sort']) ) {
$where .=" ORDER By ".key($params['sort']) .' '.current($params['sort'])." ";
}
// getting total number records without any search
$sql = "SELECT * FROM `tblExamPackages` ";
$sqlTot .= $sql;
$sqlRec .= $sql;
//concatenate search sql if value exist
if(isset($where) && $where != '') {
$sqlTot .= $where;
$sqlRec .= $where;
}
if ($rp!=-1)
$sqlRec .= " LIMIT ". $start_from .",".$rp;
$qtot = mysqli_query($this->conn, $sqlTot) or die("error to fetch tot package data");
$queryRecords = mysqli_query($this->conn, $sqlRec) or die("error to fetch package data");
while( $row = mysqli_fetch_assoc($queryRecords) ) {
$data[] = $row;
}
$json_data = array(
"current" => intval($params['current']),
"rowCount" => 10,
"total" => intval($qtot->num_rows),
"rows" => $data // total data array
);
return $json_data;
}
function updateExamPackage($params) {
$data = array();
//print_R($_POST);die;
$sql = "Update `tblExamPackages` set test_quantity = '" . $params["edit_test_quantity"] . "', price='" . $params["edit_price"]."' WHERE pkg_id='".$_POST["edit_pkg_id"]."'";
echo $result = mysqli_query($this->conn, $sql) or die("error to update package data");
}
function deleteExamPackage($params) {
$data = array();
echo "<script>
var conf = confirm('Delete No.' + $(this).data('row-id') + ' package?');
alert(conf);</script>";
$sql = "delete from `tblExamPackages` WHERE pkg_id'" . $_REQUEST["edit_pkg_id"] . "'";
echo $result = mysqli_query($this->conn, $sql) or die("error to delete package data");
}
}
?>
如果我在这里遗漏了什么,请告诉我。一切正常,除了 Delete
简答:
您的删除查询有语法错误。这在评论中有所暗示...
您还通过尝试在 php class 中使用 JavaScript 来混合服务器端和客户端。这是一个重大错误,需要一些人回过头来回顾基础知识。
长答案:
我发现您正在尝试转向 OOP 编程,并且您正在做一些正确的事情;值得注意的是,将数据库连接注入到您的 crud 对象中。
但有些事情可以做得更好。这里有一些想法——
- Use PDO 而不是 mysqli,并且 使用准备好的语句 。这很可能会消除查询中的语法错误。
- 总是 return json 来自 Ajax 请求的编码数据。我个人总是让 php 脚本响应
return json_encode( ['message'=>$message, 'data'=>$data] );
。然后您 JavaScript 回到浏览器可以决定向用户传达什么。 - 方法应该做一件事。如果该方法变得比屏幕上显示的要大,您可能需要重构。例如,
getRecords()
检查页码、创建查询、获取总数并获取所有记录。这可能应该分解成单独的方法,或者更好的是,创建一个可以注入到查询创建方法中的分页对象。
顺便说一句,为了说明准备好的语句的重要性:如果有人去了 hxxp://yourdomain/exam_package_response.php?action=delete&edit_pkg_id=1+or+1%3D1
怎么办?
答案:您刚刚丢失了此 table 中的所有数据。准备好的语句将防止这种情况。
在
deleteExamPackage($params) function
在第 7 行,在 echo 语句之前,您忘记添加
=
改变这个
`$sql = "delete from `tblExamPackages` WHERE pkg_id'" . $_REQUEST["edit_pkg_id"] . "'";`
到
$sql = `"delete from `tblExamPackages` WHERE pkg_id = '" . $_REQUEST["edit_pkg_id"] . "'";`
在一些小伙伴的指导下,我成功解决了问题。
基本上,我无法从我的 CRUD 网格中删除一行。实际上,我无法正确检测到错误。根据上面的答案和评论,我找到了错误并解决了。
以下是我为使其正常工作所做的更改。
Delete Query had a Syntax error.
我的删除查询有一个小错误。我错过了 =
登录 where
条款。虽然这不是最初的问题,但这是一个需要解决的问题。
Wasn't getting
pkg_id
sent fromAJAX
toPHP
.
所以核心问题是,我的查询正在执行,但我没有在传递的变量中获得 pkg_id
的值。实际上我没有正确调试它,否则我什至不必在这里 post 它。感谢上面的 Tim Morton 先生,我调试了这个问题。奇怪的是,使用相同的方法,我在 UPDATE
函数中获得了值,但在 DELETE
中却没有。我尝试了一些方法来解决这个问题,但无法解决。
所以我用Cookies来解决问题。解决方法是 Creating Cookie using AJAX and retrieving its value in PHP
。这是我用来执行此操作的代码。我只提到我重写的部分代码。
exam_packages.php
在 $(document).ready(function()
function createCookie(name, value, days)
{
var expires;
if (days)
{
var date = new Date();
date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
expires = "; expires=" + date.toGMTString();
}
else
{
expires = "";
}
document.cookie = escape(name) + "=" + escape(value) + expires + "; path=/";
}
并将其用作
createCookie("pkg_id", $(this).data("row-id"), "1");
在var conf = confirm('Delete No.' + $(this).data("row-id") + ' package?');
这将创建名为 pkg_id
.
exam_package_resposnse.php
已访问此文件中的 cookie 值
$pkg_id = $_COOKIE["pkg_id"];
并使用 pkg_id
作为我的 where
子句的参数。
我知道这可能不是解决此问题的正确方法,但这绝对是其中一种方法。我测试了它并且它正在工作。如果有人有更好的方法来做到这一点,请随时分享,因为它可能对其他人和我也有用。 :)
此致