MySQL事务

事物

1·在MySQL中的事务(Transaction)是由存储引擎实现的,在MySaL中,只有InnoDB存储引擎才支持事务。

2·事务处理可以用来维护数据库的完整性,保证成批的sQL语句要么全部执行,要么全部不执行。

3·事务用来管理DDL、DML、DCL操作,比如insert,update,delete语句,默认是自动提交的

 事务的特性:

原子性

事务是一个不可分割的整体,事务
开始后的所有操作,要么全部完
成,要么全部不做;


一致性

系统从一个正确的状态,迁移到另
一个正确的状态


隔离性

每个事务的对象对其他事务的操
作对象互相分离,事务提交前对其
他事务不可见


持久性


事务一旦提交,则其结果是永久性

事物的隔离级

lsolate,顾名思义就是将事务与另一个事务隔离开,因为如果一个事物正在操作的数据被另一个事务修改或删除了,那么结果就无法去达到预期

 越向下则两个事务关联程度越小,第三个是mysql默认的隔离级别

事务的隔离级别:


1.读未提交(Read uncommitted) 

一个事务可以读取另一个未提交事务的数据,最低级别,任何情况都无法保证,会造成脏读。

脏读就是在执行过程中本不应该被读取到的数据被读取了


2.读已提交(Read committed) 


一个事务要等另一个事务提交后才能读取数据,可避免脏读的发生,会造成不可重复读。

不可重复读就是A事务在没有提交事务期间得到B事务操作数据是不同的


3.可重复读(Repeatable read) 


就是在开始读取数据(事务开启)时,不再允许修改操作,可避免脏读、不可重复读的发生,
但是会造成幻读。


4.串行(Serializable 


是最高的事务隔离级别,在该级别下,事务串行化顺序执行,可以避免脏读、不可重复读与幻
读。但是这种事务隔离级别效率低下,比较耗数据库性能,一般不使用。

会设置个锁,在一边修改时,另一边不能修改
Mysql的默认隔离级别是Repeatable read.

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值