当咱们作一些网站项目的时候,都会遇到这样一类问题,删除一个栏目,而这个栏目又不是最底层栏目,也就是说,被删除的栏目拥有子栏目,这时,咱们执行删除该栏目的命令,就须要将该栏目及其子栏目一并删除,由于咱们不可能让一个类的上级栏目被删除后,子栏目还显示或存在数据库中,这时候,栏目删除的问题就来了。数据库
先上图:数组
这是一个简单的权限管理的页面,图中管理员权限为顶级权限,栏目管理为管理员权限的子权限,栏目添加又为栏目管理的子权限,这样一个三级分类,咱们想要达到的效果为:删除管理员权限,其下栏目管理、栏目添加权限全被同时删除;删除栏目管理权限,则栏目添加也同时被删除;删除栏目添加权限则只删除其自己。函数
接下来实现方法:网站
1.是控制器中简单删除方法:this
1 public function privilege_del(){ 2 $pri = D('privilege'); 3 $id = I('id'); 4 if($pri->delete($id)){ 5 $this->success('删除权限成功!',U('Privilege/privilege_lst')); 6 }else{ 7 $this->error('删除权限失败!'); 8 } 9 }
2.咱们思考,咱们想要的同时删除的结果,实际上是当咱们选择上级栏目删除时,代码首先帮咱们删除该栏目类别的最底层的子栏目,而后依次向上删除,最终删除咱们选择的上级栏目,因此咱们须要写一个前置的构造函数进行操做 _before_delete($options) 这是ThinkPHP提供给咱们的函数,他的用法是在咱们执行删除方法前,执行这个函数,其中$options为咱们要删除的信息,具体为一个二维数组,当咱们把$options dump出来时,结果为: spa
也就是说,若是咱们想要取到这条信息的id值,只须要获取$options['where']['id']便可,可是注意,若是数组中的where一样是一个数组的时候,这就意味着咱们进行的是批量删除,这也是单个删除和批量删除的区别所在,关于批量删除,以后我会再写一篇来简单介绍,此次咱们只写单个删除。code
首先,写一个获取全部数据的方法childid,这里的$priid就是咱们传进去的所要删除的那一栏的idblog
1 public function childid($priid){ 2 $data = $this->select(); 3 return $this->getchildid($data,$priid); 4 }
而后根据全部数据查找咱们要删除的栏目的下面的子栏目的id,再次建立一个方法 getchildid获取全部须要删除的id递归
1 public function getchildid($data,$parentid){ 2 static $ret=array(); 3 foreach ($data as $k => $v) { 4 if($v['parentid']==$parentid){ 5 $ret[]=$v['id']; 6 $this->getchildid($data,$v['id']); 7 } 8 } 9 return $ret; 10 }
这里又用到了递归,在全部数据中查询完下级栏目后,查询下级栏目的下级栏目,最后将该栏目的全部子栏目的id版存到ret数组中,返回。get
最后在构造函数中调用
1 public function _before_delete($options){ 2 //单个删除 3 $chilrenids =$this->childid($options['where']['id']); 4 $chilrenids = implode(',', $chilrenids); 5 if($chilrenids){ 6 $this->execute("delete from ed_privilege where id in($chilrenids)"); 7 } 8 }
将获取的id号用逗号隔开,由于此时不能再使用delete方法去删除数据,若使用则将再次调用构造函数成为死循环,因此咱们须要在这里执行SQL语句进行数据删除。
以上就是单个栏目删除的所有内容。