**概述**
事务(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接口实战