
MySQL 事务
事务处理在数据库开发过程中有着非常重要的作用,它可以保证在同一个事务中的操作具有同步性。
概念
在 MySQL 中,事务就是针对数据库的一组操作,它可以由一条或多条 SQL 语句组成,且每个 SQL 语句是互相依赖的。只要在程序执行过程中有一条 SQL 语句执行失败或发生错误,则其他语句都不会执行,也就是说事务的执行要么成功,要么就返回到事务开始前的状态,这就保证了同一事务操作的同步性和数据的完整性。
MySQL 中的事务必须满足 A、C、I、D 这 4 个基本特征。
- 原子性。原子性是指一个事务必须被视为一个不可分割的最小工作单元,只有事务中所有的数据库操作都执行成功,才是算整个事务执行成功。事务中如果有任何一个 SQL 语句执行失败,已经执行成功的 SQL 语句也必须撤销,数据库的状态退回到执行事务前的状态。
- 一致性。一致性是是指事务处理时,无论执行成功还是失败,都要保证数据库系统处于一致的状态,保证数据库系统处于一致的状态,保证数据库系统不会返回一个未处理的事务。MySQL 中的一致性主要由日志机制实现,通过日志记录数据库的所有变化,为事务恢复提供了追踪记录。
- 隔离性。隔离性是指当一个事务在执行时,不会受到其他事务的影响。保证了未完成事务的所有操作与数据库系统的隔离,直到事务完成为止,才能看到事务的执行结果。隔离性相关的技术有并发控制、可串行化、锁等。当多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务的操作数据所干扰,多个并发事务之间要相互隔离。
- 持久性。持久性是指事务一旦提交,其对数据库的修改就是永久性的。