事务概述
当多个用户访问同一份数据时,一个用户在更改数据的过程中,可能有其他用户同时发起更改请求,为保证数据库记录的更新从一个一致性状态变为另外一个一致性状态,使用事务处理是非常必要的,事务具有以下四个特性:原子性(Atomicity):事务中所有操作视为一个原子单位,即对事务所进行的数据修改等操作只能是完全回滚或完全提交一致性(Consistency):事务在完成时,必须使用所有的数据从一种一致性变更为另一种一致性状态,所有的变更都必须应用于事务的修改,以确保数据的完整性。事务的一致性由原子性、持久性和隔离性一起实现隔离性(Isolation):一个事务中的操作语句所做的修改必须与其他事务所做的修改相隔离。在进行事务查看数据时,数据所处的状态,要么是被另一个并发事务修改之前的状态,要么是被另一并发事务修改之后的状态,即当前事务不会查询由另一个并发事务正在修改的数据。隔离性由MySQL锁机制实现持久性(Durability):事务完成之后,所做的修改对数据的影响是永久的,即使系统重启或者出现系统故障,数据仍可恢复
MySQL提供了多种事务型存储引擎,如InnoDB和BDB等,而MyISAM不支持事务。为了支持事务,InnoDB存储引擎引入了与事务处理相关的REDO日志和UNDO日志,同时事务依赖于MySQL提供的锁机制1。REDO日志
事务执行时需要将执行的事务日志写入日志文件,对应的文件为REDO日志。当每条SQL进行数据更新操作时,首先将REDO日志写进日志缓冲区。当客户端执行COMMIT命令提交时,日志缓冲区的内容将被刷新到磁盘,日志缓冲区的刷新方式或者时间间隔可以通过参数innodbflushlogattrxcommit控制
REDO日志对应磁盘上的iblogifleN文件,该文件默认为5MB,建议设置为512MB,以...
(全文)