mysql 事务

18 Feb 2016

当处理一个用户的时候, 我们可能需要处理他的相关信息, 比如发表的文章, 发布的评论. 可能要删除, 可能要归档. 无论如何, 我们都需要执行一系列的 sql:

delete from user_posts where user_id=1
delete from user_comments where user_id=1
delete from users where id=1
...

那如果由于一些原因, 在删除某一个表的时候出错了, 那么就出现了不一致的情况, 之后的查询可能会发生意想不到的结果. 那么事务就出现了.

事务

一般来说,事务是必须满足4个条件(ACID): Atomicity(原子性)、Consistency(稳定性)、Isolation(隔离性)、Durability(可靠性)

使用

MySQL 的 innodb 和 bdb 支持事务.

php demo

<?php
$dbhost = 'localhost:3306';  // mysql服务器主机地址
$dbuser = 'root';            // mysql用户名
$dbpass = '123456';          // mysql用户名密码
$conn = mysqli_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
    die('连接失败: ' . mysqli_error($conn));
}
// 设置编码,防止中文乱码
mysqli_query($conn, "set names utf8");
mysqli_select_db($conn, 'test');
mysqli_query($conn, "SET AUTOCOMMIT=0"); // 设置为不自动提交,因为MYSQL默认立即执行
mysqli_begin_transaction($conn);            // 开始事务定义
 
if(!mysqli_query($conn, "insert into test (id) values(8)"))
{
    mysqli_query($conn, "ROLLBACK");     // 判断当执行失败时回滚
}
 
if(!mysqli_query($conn, "insert into test (id) values(9)"))
{
    mysqli_query($conn, "ROLLBACK");      // 判断执行失败时回滚
}
mysqli_commit($conn);            // 执行事务
mysqli_close($conn);