Skip to content

6.事务

刘广财 edited this page Mar 22, 2018 · 2 revisions

数据库事务

注意
MyISAM:不支持事务,用于只读程序提高性能。

InnoDB:支持ACID事务、行级锁、并发。

想要在一个数据库事务中运行一连串操作,可以使用\Itxiao6\Database\Capsule\Manager的transaction方法,如果事务闭包中抛出异常,事务将会自动回滚。如果闭包执行成功,事务将会自动提交。使用transaction方法时不需要担心手动回滚或提交:

# 使用默认连接
\Itxiao6\Database\Capsule\Manager::transaction(function () {
    \Itxiao6\Database\Capsule\Manager::table('users')->update(['votes' => 1]);
    \Itxiao6\Database\Capsule\Manager::table('posts')->delete();
});
# 使用指定数据库连接
\Itxiao6\Database\Capsule\Manager::connection('default') -> transaction(function () {
    \Itxiao6\Database\Capsule\Manager::table('users')->update(['votes' => 1]);
    \Itxiao6\Database\Capsule\Manager::table('posts')->delete();
});

手动使用事务

如果你想要手动开始事务从而对回滚和提交有一个完整的控制,可以使用\Itxiao6\Database\Capsule\Manager门面的beginTransaction方法:

# 开启事务
\Itxiao6\Database\Capsule\Manager::beginTransaction();

# 提交事务
\Itxiao6\Database\Capsule\Manager::rollBack();

# 回滚事务
\Itxiao6\Database\Capsule\Manager::commit();

也可以使用数据库模型进行开始事务

UserModel::beginTransaction(function () {
    \Itxiao6\Database\Capsule\Manager::table('users')->update(['votes' => 1]);
    \Itxiao6\Database\Capsule\Manager::table('posts')->delete();
});