**概述**
事務(transaction)是由查詢和/或更新語句的序列組成。 用 begin、start transaction 開始一個事務,rollback 回滾事務,commit 提交事務。 在開始一個事務后,可以有若干個 SQL 查詢或更新語句,每個SQL執行后,還應該有判斷是否正確執行的語句,以確定下一步是否回滾,若都被正確執行則最后提交事務。事務一旦回滾,數據庫則保持開始事務前狀態。就好象一個被編輯的文件不存盤退出,自然還是保持文件原來的樣子。所以,事務可被視為原子操作,事務中的 SQL,要么全部執行,要不一句都不執行。
**注意**
~~~
在?MySQL?中只有使用了?Innodb?數據庫引擎的數據庫或表才支持事務。
~~~
**使用方法**
~~~
1、開啟事務
$db->beginTransaction();
2、根據結果決定回滾或者提交
$db->rollback();?或者?$db->commit();
~~~
**演示數據表 accounts**
~~~
DROP?TABLE?IF?EXISTS?`accounts`;
CREATE?TABLE?`accounts`?(
??`id`?int(10)?NOT?NULL?AUTO_INCREMENT,
??`name`?varchar(20)?DEFAULT?NULL,
??`balance`?int(10)?DEFAULT?NULL,
??PRIMARY?KEY?(`id`)
)?ENGINE=InnoDB?AUTO_INCREMENT=3?DEFAULT?CHARSET=utf8;
--?----------------------------
--?Records?of?accounts
--?----------------------------
INSERT?INTO?`accounts`?VALUES?('1',?'張三',?'1000');
INSERT?INTO?`accounts`?VALUES?('2',?'李四',?'0');
~~~
**事務演示**
~~~
//演示:?從張三賬戶轉賬給李四200元
$db?=?db('accounts');
//開啟事務
$db->beginTransaction();
//扣除張三?200?元
$db->where('id?=??',?array(1))->field('balance',?-200);
//給李四賬戶充值?200元
$res?=?$db->where('id?=??',?array(2))->field('balance',?200);
$rowCount?=?$db->rowCount();
echo?'觀察更新后影響數據數量確保一定更新成功?['.$rowCount.']<br?/>';
//如果給李四賬戶充值?200元不成功則回滾
if(!$res?||?$rowCount?<?1){
????echo?'回滾...';
????$db->rollback();
}else{
????//成功則進行提交
????$db->commit();
}
~~~
- 序言
- 環境需求
- 目錄結構&命名規則
- 初始化
- 第一章 控制器與路由
- 1.1 創建控制器
- 1.2 基礎控制器
- 1.3 url 解析規則
- 第二章 數據與模型
- 1.1 數據庫配置
- 1.2 獲取數據庫操作對象
- 1.3 數據庫操作(CRUD)
- 1.4 數據分頁詳解
- 1.5 phpGrace事務處理
- 1.6 數據驗證
- 1.7 表單令牌
- 1.8 全局模型創建與調用
- 第三章 視圖
- 1.1 創建視圖文件
- 1.2 視圖調用及引用
- 1.3 視圖文件路徑模式
- 第四章 會話機制
- 1.1 cookie 操作
- 1.2 文件型 SESSION
- 1.3 memcache形式的 SESSION
- 1.4 redis 形式的 SESSION
- 第五章 緩存機制
- 1.1 緩存的概述和配置
- 1.2 文件型緩存
- 1.3 memcache 形式的緩存
- 1.4 redis 形式的緩存
- 第六章 配置、常量、語言
- 1.1 全局配置、分組配置
- 1.2 預定義常量
- 1.2 語言包使用說明
- 第七章 工具大全
- 1.1 函數小工具
- 1.2 函數工具庫
- 第八章 安全與擴展
- 1.1 框架部署安全
- 1.2 phpGrace 安全概述
- 1.3 phpGrace 擴展說明
- 實戰項目(內容管理系統)
- 前端實戰graceui
- 項目API接口實戰