1、单条数据删除

思路:首先,需要也只能允许用户勾选一条数据,然后弹出一个确认框,问用户是否真的要删除?如果是,就把ID传递到PHP,然后写一个delete语句,通过ID去删除即可。





画好了按钮之后,编写其点击事件。

前台代码:

function singleDelete(){

	var rows = $("#grid0").datagrid("getSelections");  // []

	if(rows.length != 1){

		$.messager.alert("系统提醒","请勾选一条数据!");
return;
} //让用户再次确认是否要删除?
if( confirm("您确认要删除这条数据吗?") ){ //获取这条数据的ID
var id = rows[0].id; //通过jQuery给我们提供的ajax异步提交函数,把ID传递到后台
// 后台响应resultData : {errCode:-1,errMsg:""}
$.post("deleteDept.php",{'id':id},function(data){
if(data.errCode < 0){
$.messager.alert("系统提醒","后台程序发生错误,原因是<br>:<font style='color:red;'>"+data.errMsg+"</font>");
}else{
$.messager.alert("系统提醒","删除成功!");
search();
} },"json");
} }

如果你是做前端的,往往可以不用关心后台代码如何实现,反正都是用ajax去提交请求,比如,这个例子中,我们提交的地址就是deleteDept.php 。我压根不去关心你后端如何实现,这是做后台程序的同事该烦恼的事情,我只关心,如何去处理你给我返回的数据。比如,公司规定,ajax提交过来的请求,响应格式为 {errCode:0 , errMsg : “” },我们只需要对应这种格式在回调函数中作出响应的处理即可。

后代代码:

<?php

	//连接MySQL数据库
$conn = mysql_connect("localhost","root","");
$db = mysql_select_db("test",$conn);
mysql_query("set names utf8"); $resultData = array();
$resultData['errCode'] = 0;
$resultData['errMsg'] = "";
$id = null;
if(isset($_POST['id']) && $_POST['id'] != null){
$id = $_POST['id']; mysql_query("delete from tm_dept where id = '$id'") or die(err()); echo json_encode($resultData); } function err(){
$resultData['errCode'] = -1;
$resultData['errMsg'] = mysql_error();
echo json_encode($resultData);
} ?>

/2、批量删除

思路:允许用户勾选多条数据,但是不允许一条都不勾选。如果用户一条都不勾选,就提示“请至少勾选一条数据!”。

比如,我现在勾选了两条数据,就把这两条数据的ID用逗号拼接的方式,变成一个字符串,如:“20,30”。把这个玩意用ajax提交到PHP。然后,PHP中,用sql语句,进行删除。

Sql语句大概长这个样子:

DELETE from tm_dept where id in (13,15);

2.1 允许用户勾选多条数据,但是不允许一条都不勾选

按钮的渲染:

<a href="javascript:deleteBatch()"
class="easyui-linkbutton"
iconCls="icon-remove" plain="true">批量删除</a>

function deleteBatch(){

	var rows = $("#grid0").datagrid("getSelections");

	if(rows.length == 0){
$.messager.alert("系统提醒","请至少勾选一条数据!");
return;
}
}

2.2 将勾选的数据ID做成逗号分割的字符串

第一个想法,可以去遍历勾选的所有行,然后取出每一行的ID

	for(var i=0;i<rows.length;i++){
var row = rows[i]; alert(row.id);
}

然后,先考虑如何去把这些ID用个什么东西装起来?比如,用数组。

装好以后,再去把数组变成逗号分隔的字符串~!

var ids = [];
for(var i=0;i<rows.length;i++){
var row = rows[i];
ids.push(row.id);
}
console.log(ids.toString());

2.3 把这个字符串传递到php

$.post("deleteDept.php",{ids:ids.toString()},function(data){
if(data.errCode < 0){
$.messager.alert("系统提醒","后台程序发生错误,原因是<br>:<font style='color:red;'>"+data.errMsg+"</font>");
}else{
$.messager.alert("系统提醒","删除成功!");
search();
} },"json");

在php中测试能不能接收到ids:

在php中根据这些ID去批量删除

<?php

	//连接MySQL数据库
$conn = mysql_connect("localhost","root","");
$db = mysql_select_db("test",$conn);
mysql_query("set names utf8"); $resultData = array();
$resultData['errCode'] = 0;
$resultData['errMsg'] = "";
$id = null;
$ids = null; if(isset($_POST["ids"]) && $_POST["ids"] != null){
$ids = $_POST['ids']; mysql_query("delete from tm_dept where id in ($ids)") or die(err()); echo json_encode($resultData); } if(isset($_POST['id']) && $_POST['id'] != null){
$id = $_POST['id']; mysql_query("delete from tm_dept where id = '$id'") or die(err()); echo json_encode($resultData); } function err(){
$resultData['errCode'] = -1;
$resultData['errMsg'] = mysql_error();
echo json_encode($resultData);
} ?>

【php增删改查实例】第十二节 - 数据删除功能的更多相关文章

  1. python链接oracle数据库以及数据库的增删改查实例

    初次使用python链接oracle,所以想记录下我遇到的问题,便于向我这样初次尝试的朋友能够快速的配置好环境进入开发环节. 1.首先,python链接oracle数据库需要配置好环境. 我的相关环境 ...

  2. java:JSP(JSPWeb.xml的配置,动态和静态导入JSP文件,重定项和请求转发,使用JSP实现数据库的增删改查实例)

    1.JSP的配置: <%@ page language="java" import="java.util.*" pageEncoding="UT ...

  3. yii2.0增删改查实例讲解

    yii2.0增删改查实例讲解一.创建数据库文件. 创建表 CREATE TABLE `resource` ( `id` int(10) NOT NULL AUTO_INCREMENT, `textur ...

  4. 百度鹰眼Java接口调用增删改查实例

    因感觉百度鹰眼的使用场景比较符合实际业务,于是对百度鹰眼做了简单功能调试.刚开始使用springframework封装的RestTemplate,但是测试提示ak参数不存在.后又试了几种方法,均提示a ...

  5. 关于利用PHP访问MySql数据库的逻辑操作以及增删改查实例操作

    PHP访问MySql数据库 <?php //造连接对象$db = new MySQLi("localhost","root","",& ...

  6. 【黑马Android】(04)数据库的创建和sql语句增删改查/LinearLayout展示列表数据/ListView的使用和BaseAdater/内容提供者创建

    数据库的创建和sql语句增删改查 1. 载入驱动. 2. 连接数据库. 3. 操作数据库. 创建表: create table person( _id integer primary key, nam ...

  7. Maven多模块项目+MVC框架+AJAX技术+layui分页对数据库增删改查实例

    昨天刚入门Maven多模块项目,所以简单写了一个小测试,就是对数据库单表的增删改查,例子比较综合,写得哪里不妥还望大神赐教,感谢! 首先看一下项目结构: 可以看到,一个项目MavenEmployee里 ...

  8. 【php增删改查实例】第四节 -自己 DIY 一个数据库管理工具

    本节介绍如何自己DIY一个数据库管理工具,可以在页面输入sql 进行简单的增删改查操作. 首先,找到xampp的安装目录,打开htdocs: 新建一个php文件,名称为 mysqladmin.php ...

  9. 【php增删改查实例】第十节 - 部门管理模块(新增功能)

    正常情况下,在一个部门管理页面,不仅仅需要展示列表数据,还需要基本的增删改操作,所以,我们先把之前写好的新增功能集成进来. 在toolbar中,添加一个新增按钮. <div id="t ...

随机推荐

  1. 2018最新大厂Android面试真题

    前言 又到了金三银四的面试季,自己也不得不参与到这场战役中来,其实是从去年底就开始看,android的好机会确实不太多,但也还好,3年+的android开发经历还是有一些面试机会的,不过确实不像几年前 ...

  2. SDK Manager

    dx.bat :将所有的.class文件变成一个.dex文件. aapt:Android Application package tools 安卓应用的打包工具. adb:Android Debug ...

  3. Echarts地图展示及属性分析

    Echarts,一个效果非常棒的可视化库,可以生产各种图表,动态展示,附上官方网址:http://www.echartsjs.com/index.html 之前带本科实习时有同学用过,狗哥的博客也用这 ...

  4. EntityFramework Code-First 简易教程(五)-------领域类配置

    前言:在前篇中,总是把领域类(Domain Class)翻译成模型类,因为我的理解它就是一个现实对象的抽象模型,不知道对不对.以防止将来可能的歧义,这篇开始还是直接对Domain Class直译. 前 ...

  5. npm install node-sass 本地安装失败

    $ npm install --save node-sass --registry=https://registry.npm.taobao.org --disturl=https://npm.taob ...

  6. 用Python实现数据结构之树

    树 树是由根结点和若干颗子树构成的.树是由一个集合以及在该集合上定义的一种关系构成的.集合中的元素称为树的结点,所定义的关系称为父子关系.父子关系在树的结点之间建立了一个层次结构.在这种层次结构中有一 ...

  7. Python基础知识:类

    初级篇 面向过程:根据业务逻辑从上到下写垒代码 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可 面向对象:对函数进行分类和封装,让开发“更快更好更强...” 1.面向对象三大特性 ...

  8. JSON语法规则

    JSON 语法规则 JSON 语法是 JavaScript 对象表示法语法的子集. 数据在名称/值对中 数据由逗号分隔 花括号保存对象 方括号保存数组 JSON 名称/值对 JSON 数据的书写格式是 ...

  9. java通过传入的日期,获取所在周的周一至周日

    public static void main(String[] args) { try { SimpleDateFormat sdf=new SimpleDateFormat("yyyy- ...

  10. EXCEL这样根据某单元格的内容来改变整行颜色

    1.选择你需要改变颜色的单元格列数,然后打开“格式”--“条件格式”: 2.选择“公式”一项,在后面输入=$L1=2050,然后点开下面的“格式”按钮设置好格式. 3.基本上就OK了,注意在输入公式的 ...