2021-03-10

事务的特征
事务四大特征(ACID):
原子性(A):事务是最小单位,不可再分;
一致性©:事务要求所有的DML语句操作的时候,必须保证同时成功或者同时失败;
隔离性(I):同一时间,只允许一个事务请求同一数据,不同的事务之间彼此没有任何干扰;
持久性(D):是事务的保证,事务终结的标志(内存的数据持久到硬盘文件中)。
事务的隔离级别
事务的隔离级别有4个:
读未提交(read uncommitted):事务A和事务B,事务A未提交的数据,事务B可以读取到,这里读取到的数据叫做“脏数据”。这种隔离级别最低,一般是在理论上存在,数据库隔离级别一般都高于该级别;
读已提交(read committed):事务A和事务B,事务A提交的数据,事务B才能读取到。这种隔离级别高于读未提交,可以避免“脏数据”。到如果事务A多次读取同一数据,而事务B在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果不一致,这种现象称为“不可重复读”;
可重复读(repeatable read):事务A和事务B,事务A提交之后的数据,事务B读不到事务A提交的数据。这种隔离级别高于读已提交,但如果事务A在修改数据的过程中(比如将所有记录状态设为1 ),如果事务B向同一张表中插入一条新纪录(状态为0),事务A提交后再次查询表,会发现有一条记录状态没有改成1,好像发生了幻觉,这种现象称为“幻读”。可重复读是MySQL默认隔离级别;
串行化(seralizable):事务A和事务B,事务A在操作数据库时,事务B只能排队等待。这种级别可以避免“幻读”,每一次读取的都是数据库中真实存在数据,事务A与事务B串行,而不并发。

你可能感兴趣的:(笔记)