前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >vhr部门管理数据库设计与编程

vhr部门管理数据库设计与编程

作者头像
江南一点雨
发布2018-04-02 16:22:08
1K0
发布2018-04-02 16:22:08
举报
文章被收录于专栏:玩转JavaEE

项目地址:https://github.com/lenve/vhr

好了,那我们本文主要来看看数据库的设计与存储过程的编写。

部门数据库整体来说还是比较简单,如下:

都是常规字段,脚本可以在项目中下载。depPath是为了查询方便,isParent表示该条是否是父部门。为了简化程序中的逻辑,depPath的设置和isParent的设置我都在存储过程中完成。

添加部门存储过程

添加部门存储过程如下:

代码语言:javascript
复制
DELIMITER $$

USE `vhr`$$

DROP PROCEDURE IF EXISTS `addDep`$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `addDep`(in depName varchar(32),in parentId int,in enabled boolean,out result int,out result2 int)
begin
  declare did int;
  declare pDepPath varchar(64);
  insert into department set name=depName,parentId=parentId,enabled=enabled;
  select row_count() into result;
  select last_insert_id() into did;
  set result2=did;
  select depPath into pDepPath from department where id=parentId;
  update department set depPath=concat(pDepPath,'.',did) where id=did;
  update department set isParent=true where id=parentId;
end$$

DELIMITER ;

关于这个存储过程,我说如下几点:

1.该存储过程接收五个参数,三个输入参数分别是部门名称、父部门Id,该部门是否启用,两个输出参数分别表示受影响的行数和插入成功后id的值。

2.存储过程首先执行插入操作,插入完成后,将受影响行数赋值给result。

3.然后通过last_insert_id()获取刚刚插入的id,赋给result2。

4.接下来查询父部门的depPath,并且和刚刚生成的id组合后作为刚刚插入部门的depPath。

5.将父部门的isParent字段更新为true。

将这些逻辑写在存储过程中,可以简化我们代码中的逻辑。

删除部门存储过程

删除部门也被我写成了存储过程,主要是因为删除过程也要做好几件事,核心代码如下:

代码语言:javascript
复制
DELIMITER $$

USE `vhr`$$

DROP PROCEDURE IF EXISTS `deleteDep`$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `deleteDep`(in did int,out result int)
begin
  declare ecount int;
  declare pid int;
  declare pcount int;
  select count(*) into ecount from employee where departmentId=did;
  if ecount>0 then set result=-1;
  else 
  select parentId into pid from department where id=did;
  delete from department where id=did and isParent=false;
  select row_count() into result;
  select count(*) into pcount from department where parentId=pid;
  if pcount=0 then update department set isParent=false where id=pid;
  end if;
  end if;
end$$

DELIMITER ;

关于这个存储过程,我说如下几点:

1.一个输入参数表示要删除数据的id,一个输出参数表示删除结果。

2.如果该部门下有员工,则该部门不能被删除。

3.删除该部门时注意加上条件isParent=false,即父部门不能被删除,这一点我在前端已经做了判断,正常情况下父部门的删除请求不会被发送,但是考虑到前端的数据不能被信任,所以后台我们也要限制。

4.删除成功之后,查询删除部门的父部门是否还有其他子部门,如果没有,则将父部门的isParent修改为false。

其他一些琐碎的技术就不值得介绍了,大家在源码中自行研究,有问题欢迎留言讨论。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-01-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 江南一点雨 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 添加部门存储过程
  • 删除部门存储过程
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档