本文實例講述了thinkPHP5.0框架事務(wù)處理操作。分享給大家供大家參考,具體如下:
事務(wù)的調(diào)用在mysql里需要注意下數(shù)據(jù)庫引擎,處理前先查看一下
刪除方法:
public function del()
{
$cate = new CateModel;
$id=input('id');
$selectID=$cate->find($id);
if($id == ''){
$this->error('請不要惡意測試');
}
//調(diào)用事務(wù)刪除
$del=$cate->shiwu($id);
if($del == true){
$this->success('刪除成功/!');
}else{
$this->error('刪除失敗/!');
}
}
調(diào)用事務(wù)刪除
//事務(wù)處理刪除
public function shiwu($id)
{
$cates=Cate::getChildId($id);
Db::startTrans($id,$cates); //$cates是所有子分類的一維數(shù)組
try{
Db::table('tp_cate')->where('id','in',$cates)->delete(); //刪除所有子分類
Db::table('tp_cate')->where('id',$id)->delete(); //刪除自身
// 提交事務(wù)
Db::commit();
return true;
} catch (\Exception $e) {
// 回滾事務(wù)
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;
}
更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《codeigniter入門教程》、《CI(CodeIgniter)框架進階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術(shù)總結(jié)》。
希望本文所述對大家基于ThinkPHP框架的PHP程序設(shè)計有所幫助。
您可能感興趣的文章:- ThinkPHP 3.2.2實現(xiàn)事務(wù)操作的方法
- Thinkphp事務(wù)操作實例(推薦)
- thinkPHP框架中執(zhí)行事務(wù)的方法示例
- ThinkPHP實現(xiàn)事務(wù)回滾示例代碼
- thinkphp 多表 事務(wù)詳解
- php中在PDO中使用事務(wù)(Transaction)
- php+mysql事務(wù)rollbackcommit示例
- 解析php mysql 事務(wù)處理回滾操作(附實例)
- PHP中實現(xiàn)MySQL嵌套事務(wù)的兩種解決方案
- php事務(wù)回滾簡單實現(xiàn)方法示例
- thinkPHP事務(wù)操作簡單案例分析