事物
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.