新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章将为大家详细讲解有关怎么在thinkPHP5.0框架中对事务进行处理,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
创新互联公司是一家专业从事做网站、网站建设的网络公司。作为专业网站设计公司,创新互联公司依托的技术实力、以及多年的网站运营经验,为您提供专业的成都网站建设、成都全网营销推广及网站设计开发服务!事务的调用在mysql里需要注意下数据库引擎,处理前先查看一下
删除方法:
public function del() { $cate = new CateModel; $id=input('id'); $selectID=$cate->find($id); if($id == ''){ $this->error('请不要恶意测试'); } //调用事务删除 $del=$cate->shiwu($id); if($del == true){ $this->success('删除成功/!'); }else{ $this->error('删除失败/!'); } }
调用事务删除
//事务处理删除 public function shiwu($id) { $cates=Cate::getChildId($id); Db::startTrans($id,$cates); //$cates是所有子分类的一维数组 try{ Db::table('tp_cate')->where('id','in',$cates)->delete(); //删除所有子分类 Db::table('tp_cate')->where('id',$id)->delete(); //删除自身 // 提交事务 Db::commit(); return true; } catch (\Exception $e) { // 回滚事务 Db::rollback(); return false; } }
getChildId方法
public function getChildId($id) { $cateres=Cate::select(); return $this->_getChildId($cateres,$id); } public function _getChildId($cateres,$id) { static $arr = array(); foreach ($cateres as $k => $v) { if($id == $v['pid']){ $arr[] = $v['id']; $this->_getChildId($cateres,$v['id']); } } return $arr; }
关于怎么在thinkPHP5.0框架中对事务进行处理就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。