互联网面试宝典

您现在的位置是: 首页 > MySQL

问题详情

MySQL 中事务有哪些特性?底层实现原理是什么?

面试宝典 2023-06-12 Web前端开发工程师 104
MySQL中事务的特性如下:

1. 原子性:事务中的所有操作要么全部提交成功,要么全部失败回滚。

2. 一致性:事务的执行不会破坏数据库的完整性和约束条件。

3. 隔离性:同时执行的多个事务之间是相互隔离的,互不干扰,每个事务的结果对其他事务是不可见的。

4. 持久性:事务一旦提交,其结果就会被持久化到数据库中,即使系统崩溃也不会丢失。

MySQL底层事务实现原理是使用 redo log(重做日志)和 undo log(回滚日志)来保证事务的ACID属性。

redo log记录了事务所做的修改操作,当数据库崩溃后,可以通过redo log恢复数据。

undo log记录了事务所做的修改操作的反向操作,当事务回滚或者数据库崩溃后,可以通过undo log将数据恢复到修改之前的状态。