1.什么是事务?
开发中一组业务逻辑,要么全部成功,要么全部失败。
2.事务有哪些特性?ACID
- 原子性:不可分割 (整个事务中的所有操作要么全部完成,要么全部不完成。)
- 一致性:事务操作前后数据一直,数据完整。
- 隔离性:两个事务并发(一个事务的执行不能被其他事务干扰)
- 持久性:事务提交不能反悔(已提交的事务对数据库对象的更改应该永久保存在数据库中)
3.存在隔离问题?
- 脏读 (当一个事务读取了另一个未提交事务的数据时,如果未提交事务回滚,读取的数据就是无效的。这可能导致数据不一致。)
- 不可重复度 (在一个事务中,多次读取同一行数据,但在事务执行期间,其他事务修改了该行数据,导致每次读取得到的结果不一致。)
- 虚读/幻读 (在一个事务中,多次查询同一个范围的数据,但在事务执行期间,其他事务对该范围内的数据进行了插入或删除操作,导致每次查询结果的行数不一致。)
4.隔离级别有哪些?
- 读未提交 (允许一个事务读取另一个事务未提交的数据,可能导致脏读、幻读、不可重复读等问题。)
- 读已提交 (一个事务只能读取另一个事务已经提交的数据,避免了脏读问题,但是可能会出现幻读和不可重复读问题。)
- 可重复读 (一个事务在执行期间能看到同一行上已经提交的数据,保证了每次读取的一致性,但不能保证不出现幻读问题。)
- 串行化 (最高的隔离级别,保证事务的串行执行,可以有效地防止脏读、不可重复读和幻读问题,但是会影响并发性能。)