您的位置:首页 > 数据库 > MySQL

MySql中的事务

2016-01-28 20:10 806 查看
一.MySQL的事务支持不是绑定在MySQL服务器本身,而是与存储引擎相关
1.MyISAM:不支持事务,用于只读程序提高性能
2.InnoDB:支持ACID事务、行级锁、并发

二.一个事务是一个连续的一组数据库操作,就好像它是一个单一的工作单元进行。换言之,永远不会是完整的事务,除非该组内的每个单独的操作是成功的。如果在事务的任何操作失败,则整个事务将失败。
实际上,会俱乐部许多SQL查询到一个组中,将执行所有的人都一起作为事务的一部分。
事务的特性:

事务有以下四个标准属性的缩写ACID,通常被称为:

原子性: 指一组操作,要么都成功执行,要么都不执行
一致性: 确保数据库正确地改变状态后,成功提交的事务。
隔离性: 在所有的操作没有执行完毕之前, 会话不能够看到中间改变的过程。
持久性: 确保提交的事务的结果或效果的系统出现故障的情况下仍然存在。事务产生的影响不能够撤销

三.事务的操作
开启事务:
start transaction
要执行的sql语句1
要执行的sql语句2

........
Commit 提交
Rollback 回滚
注意:当一个事务commit,或者rollback就结束了

在MySQL中,事务开始使d用COMMIT或ROLLBACK语句开始工作和结束。开始和结束语句的SQL命令之间形成了大量的事务。
COMMIT & ROLLBACK:

这两个关键字提交和回滚主要用于MySQL的事务。
当一个成功的事务完成后,发出COMMIT命令应使所有参与表的更改才会生效。
如果发生故障时,应发出一个ROLLBACK命令返回的事务中引用的每一个表到以前的状态。
四.Mysql中事务实现的原理



注:在不使用事务的时候调用的SQL语句直接作用于表,在使用了事务后sql语句首先记录在了事务日志文件中,等到commit后才作用于表中。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: