**概述**
事務(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 目錄結構及命名
- 1.4 初始化、原理、分組
- 1.5 兼容7.2php
- 第二章 控制器和路由
- 2.1 創建控制器
- 2.2 基礎控制器
- 2.3 URL解析
- 2.4 自定義路由
- 2.5 URL路由生成
- 第三章 數據和模型
- 3.1 數據庫的配置
- 3.2 獲取數據庫對象
- 3.3 數據庫操作
- 3.4 數據分頁詳情
- 3.5 事務操作&處理
- 3.6 數據驗證
- 3.7 表單驗證
- 3.8 全局模型創建與調用
- 第四章 視圖
- 4.1 視圖文件的創建
- 4.2 視圖調用及引用
- 4.3 視圖文件路徑模式
- 第五章 會話機制
- 5.1 cookie 操作
- 5.2 文件型 SEssion
- 5.3 session[memcache]
- 5.4 session[redis]
- 第六章 緩存機制
- 6.1 緩存的簡介和配置
- 6.2 文件型緩存
- 6.3 memcache 形式的緩存
- 6.4 redis 形式的緩存
- 第七章 配置 常量 語言
- 7.1 全局配置&分組配置
- 7.2 預定義常量
- 7.3 語言包使用說明
- 第八章 工具擴展
- 8.1 函數小工具
- 8.2 工具類函數
- 第九章 安全配置擴展
- 9.1 框架安全部署
- 9.2 常規安全配置
- 9.3 如何去擴展
- 附錄:擴展工具類
- 一 、圖片處理類
- 二、文件上傳類
- 三、IP地址獲取類