9. 编辑部门功能的实现

思路:只允许用户勾选一条数据,点击编辑按钮,会跳出一个和新增数据类似的对话框。然后,用户可以修改部门名称和部门编码。点击保存按钮,提示修改成功。

9.1 前台代码编写

<a href="javascript:openModifyDialog()" class="easyui-linkbutton" iconCls="icon-edit" plain="true">编辑部门</a>





现在点击编辑部门按钮是没有用的,因为openModifyDialog方法还未编写,所以,当务之急就去script标签块中添加这个方法。

function openModifyDialog(){

	//1. 获取用户选中的所有行
var rows = $("#grid0").datagrid("getSelections"); if(rows.length != 1){ $.messager.alert("系统提醒","请勾选一条数据!");
return;
} //2. 打开一个编辑窗口,把勾选的信息填充进去
$("#dialog0").dialog("open");
$("#dialog0").dialog("setTitle","部门修改"); $("#form0").form("load",rows[0]); }

因为修改数据的时候,还需要传给后台一个ID,所以这个ID我们设置为一个隐藏的input框:



为了保证先打开修改窗口后,再打开新增窗口,ID残留的问题,我们需要在打开新增页面的时候,就去把ID清空掉。

function openDialog(){
$("#dialog0").dialog("open"); //如果有ID,就清除
$("#id").val(""); }

9.2 后台代码编写

10. 新增部门的时候,不允许部门编号重复

思路:deptid 传到后台的时候,先判断这个deptid在数据库中是否存在?如果存在,就提示“该部门编号重复!” 前台页面。如果不重复,继续之前的保存逻辑。

判断是否重复的方法:

SELECT count(1) as total from tm_dept

where deptid = 'BM_001'

首先,在saveDept.php文件中,把ResultData对象的定义放到最上面:

然后,在新增的逻辑中,添加如下代码,完成部门编号的非重复检测。

11. 修改部门的时候,不允许部门编号重复

这里会出现一种比较麻烦的情况。

部门编号是不允许重复的,如果我现在修改一个部门信息:

假如部门编号不改,我就把科技部改成科技2部。就会遇到一个问题。

1.如果后台进行部门编号的非重复检测,那么BM_001的确在数据库中是存在的,就是这条未修改前的数据。因此,无法进行保存。

2.如果后台不进行部门编号的非重复检测,那么,如果有人把BM_001改成其他已经存在的部门编号,比如BM_002,那么,数据库就会存在两条相同的数据了。

代码:

//根据ID是否传过来判断是新增还是修改?
if(isset($_POST['id']) && $_POST['id'] != null){
$id = $_POST['id']; //先要判断本次修改的部门编号是否和修改前一致? $rs = mysql_query("SELECT deptid from tm_dept where id = $id"); while($row = mysql_fetch_array($rs)){ if($row["deptid"] == $deptid){
$sql = "update tm_dept set deptname = '$deptname' , deptid = '$deptid' where id = $id";
}else{
//判断部门编号deptid是否重复?
$rs = mysql_query("SELECT count(1) as total from tm_dept where deptid = '$deptid'"); while($row = mysql_fetch_array($rs)){
if($row["total"] > 0){
$resultData['errCode'] = -2;
$resultData['errMsg'] = "部门编号".$deptid."重复,能不能换一个啊?";
echo json_encode($resultData);
return;
}
}
} } }else{ //判断部门编号deptid是否重复?
$rs = mysql_query("SELECT count(1) as total from tm_dept where deptid = '$deptid'"); while($row = mysql_fetch_array($rs)){
if($row["total"] > 0){
$resultData['errCode'] = -2;
$resultData['errMsg'] = "部门编号".$deptid."重复,能不能换一个啊?";
echo json_encode($resultData);
return;
}
} $sql = "INSERT INTO tm_dept (id, deptid, deptname, createtime, updatetime) VALUES (NULL, '$deptid', '$deptname', now(), now());"; }
  1. 编辑部门功能的实现

    思路:只允许用户勾选一条数据,点击编辑按钮,会跳出一个和新增数据类似的对话框。然后,用户可以修改部门名称和部门编码。点击保存按钮,提示修改成功。

9.1 前台代码编写

<a href="javascript:openModifyDialog()" class="easyui-linkbutton" iconCls="icon-edit" plain="true">编辑部门</a>





现在点击编辑部门按钮是没有用的,因为openModifyDialog方法还未编写,所以,当务之急就去script标签块中添加这个方法。

function openModifyDialog(){

	//1. 获取用户选中的所有行
var rows = $("#grid0").datagrid("getSelections"); if(rows.length != 1){ $.messager.alert("系统提醒","请勾选一条数据!");
return;
} //2. 打开一个编辑窗口,把勾选的信息填充进去
$("#dialog0").dialog("open");
$("#dialog0").dialog("setTitle","部门修改"); $("#form0").form("load",rows[0]); }

因为修改数据的时候,还需要传给后台一个ID,所以这个ID我们设置为一个隐藏的input框:



为了保证先打开修改窗口后,再打开新增窗口,ID残留的问题,我们需要在打开新增页面的时候,就去把ID清空掉。

function openDialog(){
$("#dialog0").dialog("open"); //如果有ID,就清除
$("#id").val(""); }

9.2 后台代码编写

10. 新增部门的时候,不允许部门编号重复

思路:deptid 传到后台的时候,先判断这个deptid在数据库中是否存在?如果存在,就提示“该部门编号重复!” 前台页面。如果不重复,继续之前的保存逻辑。

判断是否重复的方法:

SELECT count(1) as total from tm_dept

where deptid = 'BM_001'

首先,在saveDept.php文件中,把ResultData对象的定义放到最上面:

然后,在新增的逻辑中,添加如下代码,完成部门编号的非重复检测。

11. 修改部门的时候,不允许部门编号重复

这里会出现一种比较麻烦的情况。

部门编号是不允许重复的,如果我现在修改一个部门信息:

假如部门编号不改,我就把科技部改成科技2部。就会遇到一个问题。

1.如果后台进行部门编号的非重复检测,那么BM_001的确在数据库中是存在的,就是这条未修改前的数据。因此,无法进行保存。

2.如果后台不进行部门编号的非重复检测,那么,如果有人把BM_001改成其他已经存在的部门编号,比如BM_002,那么,数据库就会存在两条相同的数据了。

代码:

//根据ID是否传过来判断是新增还是修改?
if(isset($_POST['id']) && $_POST['id'] != null){
$id = $_POST['id']; //先要判断本次修改的部门编号是否和修改前一致? $rs = mysql_query("SELECT deptid from tm_dept where id = $id"); while($row = mysql_fetch_array($rs)){ if($row["deptid"] == $deptid){
$sql = "update tm_dept set deptname = '$deptname' , deptid = '$deptid' where id = $id";
}else{
//判断部门编号deptid是否重复?
$rs = mysql_query("SELECT count(1) as total from tm_dept where deptid = '$deptid'"); while($row = mysql_fetch_array($rs)){
if($row["total"] > 0){
$resultData['errCode'] = -2;
$resultData['errMsg'] = "部门编号".$deptid."重复,能不能换一个啊?";
echo json_encode($resultData);
return;
}
}
} } }else{ //判断部门编号deptid是否重复?
$rs = mysql_query("SELECT count(1) as total from tm_dept where deptid = '$deptid'"); while($row = mysql_fetch_array($rs)){
if($row["total"] > 0){
$resultData['errCode'] = -2;
$resultData['errMsg'] = "部门编号".$deptid."重复,能不能换一个啊?";
echo json_encode($resultData);
return;
}
} $sql = "INSERT INTO tm_dept (id, deptid, deptname, createtime, updatetime) VALUES (NULL, '$deptid', '$deptname', now(), now());"; }

下载地址:https://pan.baidu.com/s/1OXvqQwAmz7usgD4KqiUXLw

【php增删改查实例】第十一节 - 部门管理模块(编辑功能)的更多相关文章

  1. 【php增删改查实例】第九节 - 部门管理模块(模糊查询)

    给datagrid添加一个工具栏. 效果: 模糊查询部门名称. 接下来,在工具栏区域画一个input框: <div id="toolbar" style="padd ...

  2. 【php增删改查实例】第八节 - 部门管理模块(编写PHP程序)

    首先,在同级目录新建一个query.php文件: 接着,去刷新页面,打开F12,NetWork,看看当前的请求能不能走到对应的php文件? 这就说明datagrid确实能够访问到query.php 只 ...

  3. 【php增删改查实例】 第二节 - MYSQL环境配置

    安装好xampp后,会自带一个mysql,也就是说,正常情况下,你直接这样: 就可以启动mysql了. 如果你了,下面的步骤就别看了哈. if( 启动成功 ){ return; } 如果你的电脑上已经 ...

  4. 【php增删改查实例】第一节 - PHP开发环境配置

    最近需要使用PHP,于是把平时的积累整理一下,就有了这个教程. 首先是环境配置: 1.操作系统:windos7 2.后台:PHP 3.前台:Html + js + css 4.数据库:MYSQL 5. ...

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

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

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

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

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

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

  8. SpringBoot JPA实现增删改查、分页、排序、事务操作等功能

    今天给大家介绍一下SpringBoot中JPA的一些常用操作,例如:增删改查.分页.排序.事务操作等功能.下面先来介绍一下JPA中一些常用的查询操作: //And --- 等价于 SQL 中的 and ...

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

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

随机推荐

  1. [20171113]修改表结构删除列相关问题3.txt

    [20171113]修改表结构删除列相关问题3.txt --//维护表结构删除字段一般都是先ALTER TABLE <table_name> SET UNUSED (<column_ ...

  2. JS代码段:返回yyyy-mm-dd hh:mm:ss

    最近做项目的时候正好用到,本着能抄就抄的心态去百度搜索现成的代码, 没想到抄下来的好几个都是错的,要么getMonth没有加1,要么10以下的数字前面没有加0, 我真是日了狗了,这次把写好的正确的直接 ...

  3. SQL中的每一张表都必须设有主键吗

    问题描述: 公司的数据库表有时候会看到没有主键的,SQL中的每一张表都必须设有主键吗? 主键的作用: 1)保证实体的完整性: 2)加快数据库的操作速度: 3)在表中添加新记录时,数据库ACCESS会自 ...

  4. MVC设计模式在网站中的应用

    MVC设计模式在网站中的应用 以淘宝的购物车为例 一.结合六个基本质量属性 可修改性 采用MVC设计模式的时候,可以将视图.模型.控制器分析,将用户动作.数据表示.应用数据分离开来,如果用户需要以不同 ...

  5. Alpha冲刺! Day6 - 砍柴

    Alpha冲刺! Day6 - 砍柴 今日已完成 晨瑶:讨论确定/解决了:网络判断使用广播方式.密集光点排布问题.丢失.db/记录html/多媒体文件的处理方式. 昭锡:Android工具包接口文档编 ...

  6. 类装载器-ClassLoader

    类装载器的工作机制 类装载器就是寻找类的字节码文件并构造出类在JVM内部表示对象的组件.在Java中,类装载器把一个类装入JVM中,需要经过以下步骤: 装载:查找和导入Class文件. 链接:执行校验 ...

  7. PyQt5 + QtDesigner

    看到网上蛮多介绍做界面开发时可以借助QtDesigner进行快速完成布局,搞了半天在电脑里却找不到该工具,网上查了一下,原来是要额外安装一个pyqt5的工具包,下面结合亲身一步一步操作记录下来,也方便 ...

  8. 【 nginx 】怎么安装nginx

    一,下载地址:http://nginx.org/en/download.html 二,下载完成之后,是一个安装包,解压之后就能直接使用 三,点击进去我们刚刚解压好的nginx的安装包,打开nginx. ...

  9. Django之Template

    模板层(template) 概念:  模板与html的区别:  模板=html+模板语法 模板语法: 1 变量:       {{}}    深度查询: 通过句点符.    列表,字典    clas ...

  10. CF848C:Goodbye Souvenir(CDQ分治)

    Description 给定长度为$n$的数组, 定义数字$X$在$[l,r]$内的值为数字$X$在$[l,r]$内最后一次出现位置的下标减去第一次出现位置的下标给定$m$次询问, 每次询问有三个整数 ...