事务
来源:互联网 发布: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。
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- 事务
- CityMaker学习教程12 osg模型的创建
- 学习python出现的问题_类初始化
- System library报错解决
- 《THINKING IN JAVA》随笔
- Openfire 性能优化
- 事务
- django中将数据导入至数据库
- android Settings之辅助功能
- 'xxx' is scheduled for addition ,but is missing
- tomcat中配置jndi数据源以便spring获取
- android toolbar 左边的空隙如何取消的办法
- vfprintf
- mybatis 自增主键配置(不同类型的数据库,代码写法不同)
- 正向代理与反向代理的区别【Nginx读书笔记】