欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

thinkPHP5.0框架事务处理操作简单示例

程序员文章站 2022-05-26 13:44:37
本文实例讲述了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程序设计有所帮助。