数据库的隔离级别、事务的特性、范式

本文详细介绍了MySQL中的四种事务隔离级别:可读未提交、可读已提交、可重复读及串行化,并解释了每种级别的具体含义及应用场景。此外,还概述了数据库的三种范式:第一范式、第二范式和第三范式,帮助读者理解如何规范地设计数据库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MySQL数据库为我们提供的四种隔离级别:

1、Read uncommitted (可读未提交):写事务阻止其他写事务,可以避免更新遗失,但是不能阻止其他读事务,会出现脏读。

2、 Read committed (可读已提交):写事务会阻止其他读事务,可避免脏读的发生,但是不可以重复读。

3、 Repeatable read (可重复读):读事务阻止其他写事务,不阻止读事务,写包括delete和update,但是不包括insert,所以会产生幻读。  

4、Serializable (串行化):读加共享锁,写加排它锁,这样读取事务可以并发,但是读写、写写之间是互斥的,基本上是一个个执行事务,所以叫串行化。

事务的四种特性:

1、原子性:事务包含的所有操作要么全部成功,要么全部失败回滚

2、一致性:一个事务执行之前和执行之后都必须处于一致性状态

3、隔离性:当多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务的操作所干扰

4、持久性:指一个事务一旦被提交了,那么对数据库中的数据的改变就是永久性的
 
数据库的范式:

1、第一范式:原子数据项不可分(数据表的每一列)

2、第二范式:实体属性完全依赖于主关键字

3、第三范式:在一个关系中不包含已在其他关系中包含的非主关键字信息。

  


  


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值