目录
一、什么是事务?
事务是应用程序中一系列严密的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消。也就是事务具有原子性,一个事务中的一系列的操作要么全部成功,要么一个都不做。
事务的结束有两种,当事务中的所以步骤全部成功执行时,事务提交。如果其中一个步骤失败,将发生回滚操作,撤消之前到事务开始时的所有操作。
二、事务的 ACID
事务具有四个特征:原子性( Atomicity )、一致性( Consistency )、隔离性( Isolation )和持续性( Durability )。这四个特性简称为 ACID 特性。
1 、原子性。事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做
2 、一致性。事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。
因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统 运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是不一致的状态。
3 、隔离性。
一个事务的执行不能由其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。
4 、持续性。
也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。
三、Mysql事务的使用
1、支持事务的表引擎
MySQL的事务支持不是绑定在MySQL服务器本身,而是与存储引擎相关
MyISAM:不支持事务,用于只读程序提高性能
InnoDB:支持ACID事务、行级锁、并发
Berkeley DB:支持事务
一个事务是一个连续的一组数据库操作,对外就好像它是一个单一的工作单元进行。如果在事务的任何操作失败,则整个事务将失败。
2、事务的使用
begin / start transaction #开启事务
commit #提交事务
rollback #回滚事务
3、使用autocommit来设置事务行为
mysql> show variables like "AUTOCOMMIT";
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit | ON |
+---------------+-------+
1)如果AUTOCOMMIT = 1(默认值)
每一个SQL语句都被认为是一个完整的事务,系统自动提交;如需要在代码中显式使用事务需要使用begin / start transaction)显式开启
2)AUTOCOMMIT = 0
SET AUTOCOMMIT = 0命令,在随后的一系列语句的作用就像一个事务,直到一个明确的COMMIT语句才会提提交下事务
4、PHP实现事务
<?php
$conn = mysql_connect('localhost','root','yourpassword')or die(mysql_error());
mysql_select_db('test',$conn);
mysql_query('set names utf8');
//开启事务
mysql_query('START TRANSACTION') or die(mysql_error());
$sqlA = "update A set account=account-1";
if(!mysql_query($sqlA)){
//判断当执行失败时回滚
mysql_query('ROLLBACK') or exit(mysql_error());
exit();
}
$sqlB="update B set account=account+1";
if(!mysql_query($sqlB)){
//判断当执行失败时回滚
mysql_query('ROLLBACK') or exit(mysql_error());
exit();
}
//执行事务
mysql_query('COMMIT')or die(mysql_error());
mysql_close($conn);
?>