这篇文章主要介绍了thinkPHP5.0框架事务处理操作,结合实例形式分析了thinkPHP5针对删除操作的事务处理相关操作技巧,需要的朋友可以参考下
本文实例讲述了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程序设计有所帮助。
				 沃梦达教程
				
			本文标题为:thinkPHP5.0框架事务处理操作简单示例
				
        
 
            
        基础教程推荐
             猜你喜欢
        
	     - PHP手机短信验证码实现流程详解 2022-10-18
 - PHP判断一个字符串是否是回文字符串的方法 2024-01-31
 - Yii框架连表查询操作示例 2023-02-13
 - php实现数组筛选奇数和偶数示例 2024-02-05
 - PHP+MySQL+sphinx+scws实现全文检索功能详解 2023-01-31
 - php数组函数序列之array_sum() – 计算数组元素值之和 2024-01-15
 - 设定php简写功能的方法 2023-03-17
 - PHP实现文件下载【实例分享】 2024-04-27
 - php实现构建排除当前元素的乘积数组方法 2022-11-23
 - PHP实现抽奖系统的示例代码 2023-06-26
 
    	
    	
    	
    	
    	
    	
    	
    	
						
						
						
						
						
				
				
				
				