MySQL事务

事务的ACID(acid)属性:

➢1.原子性( Atomicity )

原子性是指事务是-个不可分割的工作单位,事务中的操作要么:都发生,要么都不发生。

➢2.致性( Consistency)

事务必须使数据库从一个致性状态变换到另外一个致性状态

➢3.隔离性(Isolation)

事务的隔离性是指一个事务的执行不能被其他事务干扰,即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。

➢4.持久性(Durability )

持久性是指一个事务一且被提交, 它对数据库中数据的改变就是永久性的,接下来的其他操作和数据库故障不该对其有任何影

 

 

事务的创建:

隐式事务:事务没有明显的开始和结束标记

比如:insertupdatedelete

 

这是两个单独的事务

Update set 张三的余额=500 where name=张三  

Update set 李四的余额=1500 where name=李四

而这两个事务应该是一个事务,这时要用显式事务

 

显式事务:事务有明显的开始结束标记

前提:必须先设置自动提交功能为禁用;

Set autocommit=0;  只针对当前事务有效

 

步骤一:

Set autocommit=0;

Start transaction;可选的

步骤二:编写事务中的SQL语句(select insert update delete

语句1

语句2

..........

步骤三:结束事务

Commit;提交事务

Rollback;回滚事务

 

 

对于同时运行的多个事务,当这些事务访问数据库中相同的数据时,如果没
有采取必的隔离机制,就公导致各种并发问题:

➢脏读:于两个事务T1T2,T1读取了已经被T2更新但还没有被提交的字段,
之后,T2回滚,T1读取的内容就是临时无效的
➢不可重复读:对两个T1T2,T1读取了个字段,然T2更新了该字段,之后,T1再次读取同一个字段,值就不同了.
➢幻读:对于两个事务T1T2,T1从个表中读取了个字段,然后T2在该插入此新的行,之后,如紧T1次读取同,就会多出几行。
数据库事务的隔离性:数据系统必须具有隔离并发运行名个事务的能力,
使它们不众相影响,避免各种并发问题.
事务与其他事务隔离的程度称为隔离级别,数据规定名种事务隔
级别,不可隔级别对不同的扰程度,离级别越,数据一致
越好,但并发性越弱。 

MySQL默认隔离级别:REPEATABLE READ

 

 

脏读

不可重复读

幻读

read uncommitted

read committed

×

repeatable read

×

×

serializable

×

×

×

 

查看隔离级别:

 

Select @@tx_isolation;

设置隔离级别:

 

Set session  transaction isolation level 隔离级别;

 

 

posted @ 2019-12-20 13:27  Cool_Yang  阅读(190)  评论(0编辑  收藏  举报