#### 前提:
> 使用事務處理的話,需要數據庫引擎支持事務處理。比如 MySQL 的 MyISAM 不支持事務處理,需要使用 InnoDB 引擎。
#### 事務操作
* 依據 tp5.1手冊提供的 [事務操作介紹](https://links.jianshu.com/go?to=https%3A%2F%2Fwww.hmoore.net%2Fmanual%2Fthinkphp5_1%2F354035),隨便寫一個例子:
> 使用場景
~~~php
Db::startTrans();
try{
Db::name('users')->insert(array('name'=>'mike','age'=>28));
Db::name('products')->where('id','=',1)->update(array('status'=>2));
Db::commit();
return json_return("事務操作成功"); // json_return() 為封裝返回json數據的方法
}catch (\Exception $e){
Db::rollback();
return json_return($e->getMessage()); // json_return() 為封裝返回json數據的方法
}
~~~
針對事務操作,我們首先需要了解事務的意義:這里不詳述了,不清楚的朋友可參考 [MySQL事務](https://links.jianshu.com/go?to=https%3A%2F%2Fwww.runoob.com%2Fmysql%2Fmysql-transaction.html) 進行了解。
> 常見問題
* 問題1:如上代碼中如果第一條新增語句 返回 true , 第二條更新語句返回 false ,那這個事務還是會 commit 的,而不是我們預期的rellback,這是為什么?
~~~php
如果想讓兩條 sql 真正按照自己的意愿都 "執行成功(都返回 true 時)" 時再提交事務,那需要這樣寫:
Db::startTrans();
try{
$res1 = Db::name('users')->insert(array('name'=>'mike','age'=>28));
$res2= Db::name('products')->where('id','=',1)->update(array('status'=>2));
}catch (\Exception $e){
Db::rollback();
}
if($re1 && $re2){
Db::commit();
return json_return("事務操作成功"); // json_return() 為封裝返回json數據的方法
}else{
Db::rollback();
return json_return($e->getMessage()); // json_return() 為封裝返回json數據的方法
}
【延伸】 事務回滾的條件指的是 sql 語法報錯,而不是增加、刪除、更改 sql 時的影響行數為0
~~~
* 問題2: 在事務中,使用了tp5 的函數 $this->success(),即使事務里面的 sql 語句都成功了,但還是走了rollback,為什么?
~~~php
Db::startTrans();
try{
Db::name('users')->insert(array('name'=>'mike','age'=>28));
Db::name('products')->where('id','=',1)->update(array('status'=>2));
Db::commit();
$this->success("事務操作成功");
}catch (\Exception $e){
Db::rollback();
$this->error($e->getMessage());
}
是因為$this->success() 這個函數的源碼其實也是會拋出異常(這里可查看$this->success() 的方法),
解決辦法:
將
catch (\Exception $exception)
改成
catch (\think\Exception\DbException $exception) // 僅catch sql 異常
即可。
~~~
作者:mike\_lp
鏈接:https://www.jianshu.com/p/d9aeabd9b368
來源:簡書
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。
- 簡介
- 前端
- html
- css
- css選擇器
- fiex布局
- 盒裝模型
- javascript
- 原型鏈
- 作用域
- 事件綁定
- dom
- bom
- jquery
- 選擇器
- jquery事件綁定
- layui
- bootstrap
- vue
- 路由(Vue Router)
- Vue CLI
- axios
- vant
- 打包部署
- 自定義組件
- 一些前端效果
- 點擊復制功能
- 后端
- php框架
- thinkphp
- 隱藏index.php
- thinkphp實現多表查詢
- thinkphp使用ajax單圖上傳
- thinkphp使用ajax圖集上傳
- thinkphp使用ajax查詢是否重名
- thinkphp使用ajax表單上傳
- where多個條件
- 郵件發送功能
- thinkphp短信寶發送短信
- tp5事務
- validate驗證二維數組
- yii2
- yii配置郵件
- yii的CRUD操作
- layui中兩種展示表單的方式
- laravel
- laravel實例
- laravel登錄
- laravel前端注冊
- laravel列表
- laravel刪除
- laravel編輯
- laravel新增
- Laravel 目錄結構
- Laravel 路由
- Laravel 控制器
- Laravel 模型讀操作
- Laravel 模型增、刪、改操作
- Laravel 中間件
- Laravel 視圖
- Laravel ,YII,thinkphp 框架的區別
- 會話控制
- session
- session存入redis
- session創建
- session刪除
- cookie
- 面向對象
- 三大特性
- 魔術方法
- 修飾符
- obj變量
- php
- php版本差異
- php7與php5的區別
- PHP 內存溢出問題
- 數據類型
- PHP 垃圾回收機制(GC)
- 文件目錄操作
- php函數
- 字符串相關函數
- 數組相關函數
- 超全局數組與超全局變量
- php魔術方法
- 引用變量
- php類庫
- 1.根據隨機數生成6位密鑰
- 2.獲取客戶端IP地址
- 3.多維數組變成一維數組
- 4.判斷是否是微信瀏覽器
- 5.判斷是否是移動端
- 6.隱藏手機號碼156***8956
- 7.隱藏郵箱 9533*****@qq.com
- 8.數組排序
- 9.添加操作日志
- 10.無線分類按子分類排序
- 11.從數組中刪除空白的元素
- 12.字符串相關類庫
- curl模擬post/get請求
- 替換中間四位數
- PHP地理位置計算
- 生成唯一訂單號
- 阿拉伯數字轉化為大寫
- 時間戳轉為中文時間
- php獲取本年、本月、本周時間戳和日期格式的實例代碼(分析)
- 去除數據庫的數據空格
- 壓縮Zip文件和文件打包下載
- PHP常用六大設計模式
- 單例模式
- 工廠模式
- 注冊樹模式
- 策略模式
- 適配器模式
- 觀察者模式
- 數據庫
- 留言板功能
- 所了解的數據庫
- sql server
- Memecached
- MongoDB
- mysql
- 存儲引擎(MyISAM與InnoDB)
- 庫表CRUD操作
- 索引
- 事務
- mysql常用命令
- 悲觀鎖和樂觀鎖
- 數據庫優化
- 大流量大并發優化
- Redis
- redis相關考點
- 開啟redis
- redis緩存cache
- redis存儲session
- redis限制提交次數
- 緩存雪崩,擊穿,穿透(copy)
- redis數據結構及使用場景
- 消息隊列
- Redis、Memecached 區別?
- phpstudy升級mysql版本
- 分表
- 讀寫分離
- linux
- 開發環境搭建
- mysql配置
- centos7(lnmp)環境搭建
- ubuntu(lnmp)環境搭建
- Nginx
- nginx四個基本功能
- nginx重啟出錯
- Nginx 的反向代理
- 用戶用戶組
- 虛擬機安裝
- linux常用命令
- chmod命令
- ubuntu下apt-get 命令
- 釋放內存
- 云鎖安裝及使用
- 大部隊搭建
- Centos開啟端口命令
- Centos禁止root登錄
- Centos7修改22端口
- Rsync備份
- 開啟端口
- 微信開發
- 輔助開發
- 網站SEO
- TCP/IP協議
- HTTP 請求全過程
- http狀態碼
- http和https的區別
- http請求三部分
- tcp三次握手
- 三次握手的作用
- tcp四次揮手
- CMS
- 織夢CMS
- 帝國cms
- wordpress
- 禪知cms
- 八大接口
- 微信支付
- 支付寶支付
- 郵件
- 微博登錄
- QQ登錄
- 快遞
- 天氣
- 常見算法
- 快速排序
- 冒泡排序
- 選擇排序
- 插入排序
- 二分查找
- 希爾排序
- V2Ray搭建
- AJAX
- GIT
- RBAC用戶權限管理數據庫設計
- 開發中遇到的一些問題
- 資料購買
- 建立ssr服務器
- 簡單建
- 申請并使用ssl證書
- 正則表達式手冊
- phpstorm
- 注冊碼
- 備用注冊碼
- 網站設計概要
- 網站相關功能代碼
- 權限(RBAC/AUTH)
- 無限級分類
- 記住登錄狀態
- email找回密碼
- 企業網站開發概要
- 網站后臺
- 文章管理
- 欄目管理 CRUD 上級欄目
- 欄目管理
- 友情鏈接
- 操作日志
- 登錄注冊
- 權限管理
- 網站配置
- 網站前臺
- 首頁
- 新聞動態
- 聯系
- 案例
- 關于
- 單店鋪商城開發概要
- 面試準備
- 有意思的面試題
- 拉鉤面試要求
- 慕課面試視頻知識總結
- 面試題匯總
- 題目1
- 一些工作的要求
- 前端炒的
- 面試項目介紹
- MySQL面試100 問
- 術語庫
- redis相關
- php操作redis
- redis消息隊列(異步)
- redis消息隊列(同步)