事务

来源:互联网 发布:c%2b%2b编程入门 编辑:程序博客网 时间:2024/05/29 13:09

http://kokoppp.iteye.com/blog/717243

http://www.runoob.com/mysql/mysql-transaction.html

事务(transaction)是由一系列操作序列构成的程序执行单元,这些操作要么都做,要么都不做,是一个不可分割的工作单位,维护了数据库的完整性。

在MySQL中只有使用了Innodb数据库引擎的数据库或表才支持事务。

事务的四个基本性质(ACID)

1. 原子性(Atomicity)

事务的原子性是指事务中包含的所有操作要么全做,要么全不做(all or none)。

2. 一致性(Consistency)

在事务开始以前,数据库处于一致性的状态,事务结束后,数据库也必须处于一致性状态。

3. 隔离性(Isolation)

事务隔离性要求系统必须保证事务不受其他并发执行的事务的影响,也即要达到这样一种效果:对于任何一对事务T1 和 T2,在事务 T1 看来,T2 要么在 T1 开始之前已经结束,要么在 T1 完成之后才开始执行。这样,每个事务都感觉不到系统中有其他事务在并发地执行。

4. 持久性(Durability)

一个事务一旦成功完成,它对数据库的改变必须是永久的,即便是在系统遇到故障的情况下也不会丢失。数据的重要性决定了事务持久性的重要性。

操作

1.        显示地开启一个事务:BEGIN或START TRANSACTION

2.        提交事务,并使已对数据库进行的所有修改成为永久性:COMMIT或COMMIT WORK

3.        结束用户的事务,并撤销正在进行的所有未提交的修改:ROLLBACK或ROLLBACK WORK

4.        在事务中创建一个保存点:SAVEPOINT一个事务中可以有多个SAVEPOINT

5.        删除一个事务的保存点:RELEASE SAVEPOINT

6.        把事务回滚到标记点:ROLLBACK TO identifier

7.        设置事务的隔离级别:SET TRANSACTION。InnoDB存储引擎提供事务的隔离级别有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ和SERIALIZABLE。

0 0
原创粉丝点击