thinkPHP5.0框架事务处理操作简单示例
程序员文章站
2022-11-14 19:56:32
本文实例讲述了thinkphp5.0框架事务处理操作。分享给大家供大家参考,具体如下:
事务的调用在mysql里需要注意下数据库引擎,处理前先查看一下
删除方法:...
本文实例讲述了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; }
更多关于thinkphp相关内容感兴趣的读者可查看本站专题:《thinkphp入门教程》、《thinkphp模板操作技巧总结》、《thinkphp常用方法总结》、《codeigniter入门教程》、《ci(codeigniter)框架进阶教程》、《zend framework框架入门教程》及《php模板技术总结》。
希望本文所述对大家基于thinkphp框架的php程序设计有所帮助。