本文实例讲述了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 Work框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
继续阅读与本文标签相同的文章
-
网络基础技术实践#网络安全基础技术实践课程
2026-05-18栏目: 教程
-
阿里云服务器计算网络增强型实例sn1ne 适合中大型网站及性能要求高的公司业务使用
2026-05-18栏目: 教程
-
前端进阶|第八天 京东笔试题,引用传参赋值无效?
2026-05-18栏目: 教程
-
阿里云弹性伸缩ESS必知必会
2026-05-18栏目: 教程
-
MySQL迁移到Cassandra
2026-05-18栏目: 教程
