设为首页 加入收藏

TOP

ThinkPHP5.0框架事务处理操作简单示例
2019-08-23 00:39:15 】 浏览:34
Tags:ThinkPHP5.0 框架 事务 处理 操作简单 示例

本文介绍ThinkPHP5.0框架事务处理操作,结合实例形式分析了ThinkPHP5针对删除操作的事务处理相关操作技巧,可以加深对ThinkPHP源码的理解,需要的朋友可以参考下

事务的调用在mysql里需要注意下数据库引擎,处理前先查看一下

删除方法:

 1 public function del()
 2 {
 3     $cate = new CateModel;
 4     $id=input('id');
 5     $selectID=$cate->find($id);
 6     if($id == ''){
 7       $this->error('请不要恶意测试');
 8     }
 9     //调用事务删除
10     $del=$cate->shiwu($id);
11     if($del == true){
12       $this->success('删除成功/!');
13     }else{
14       $this->error('删除失败/!');
15     }
16 }

调用事务删除:

 1 //事务处理删除
 2 public function shiwu($id)
 3 {
 4   $cates=Cate::getChildId($id);
 5   Db::startTrans($id,$cates);  //$cates是所有子分类的一维数组
 6   try{
 7     Db::table('tp_cate')->where('id','in',$cates)->delete(); //删除所有子分类
 8     Db::table('tp_cate')->where('id',$id)->delete(); //删除自身
 9     // 提交事务
10     Db::commit();
11     return true;
12   } catch (\Exception $e) {
13     // 回滚事务
14     Db::rollback();
15     return false;
16   }
17 }

getChildId方法:

 1 public function getChildId($id)
 2 {
 3     $cateres=Cate::select();
 4     return $this->_getChildId($cateres,$id);
 5 }
 6 public function _getChildId($cateres,$id)
 7 {
 8     static $arr = array();
 9     foreach ($cateres as $k => $v) {
10       if($id == $v['pid']){
11         $arr[] = $v['id'];
12         $this->_getChildId($cateres,$v['id']);
13       }
14     }
15     return $arr;
16 }

完毕!不知道大家学会了没有?

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇PHP几种常见魔术方法与魔术变量解.. 下一篇企业办公系统、库存管理系统定制..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目