**概述**
事务(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地址获取类