MYSQL性能调优08_事务及其ACID属性、脏读、不可重复读、幻读、隔离级别、行锁、表锁、读锁、写锁、间隙锁、临键锁(一)

①. 事务及其ACID属性


事务:一个或一组sql语句组成一个执行单元,这个执行单元要么全部执行,要么全部不执行


①. 原子性(Atomicity):原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生


②. 一致性(Consistency):一个事务执行会使数据从一个一致转态切换到另外一个一致状态

(创建订单、库存减少、积分增加是指的数据层面)


③. 隔离性(Isolation):一个事务的执行不受其他事务的干扰


④. 持久性(Durability):一个事务一旦被提交,它对数据中的数据改变就是永久性的


⑤. 事务提交的两种方式


(1). 自动提交
mysql就是自动提交的
一条DML(增删改)语句会自动提交一次事务。
(2). 手动提交
Oracle 数据库默认是手动提交事务
需要先开启事务,再提交
(3). 修改事务的默认提交方式:不建议修改
查看事务的默认提交方式:SELECT @@autocommit;
(-- 1 代表自动提交  0 代表手动提交)
修改默认提交方式: set @@autocommit = 0;


步骤 
1. 开启事务:start transaction 
[ set autocommit=0(0就是开启事务这是把转态变成开启,1就是不开启事务),强调的是转态]
2. 编写事务中的sql语句(select、insert、update、delete)
语句1;
语句2;
3.结束事务
commit提交事务
rollback回滚事务

use test;
create table account(
      id int primary key auto_increment,
      username varchar(20),
      balance double
);
insert into account(username,balance)VALUES("张无忌",1000),("赵敏",1000);
#开启事务
start transaction;
#set autocommit=0; 这是把事务的转态变成开启转态

#编写一组事务的语句;
update account set balance=500 where username='张无忌';
update account set balance=1500 where username='赵敏';
#结束事务[要么回滚,要么提交]  回滚:数据只存到了内存,实质没有改
rollback;
#commit;
select * from account;


②. 脏读、不可重复读、幻读


①. 脏读:对于两个事务T1,T2,T1读取了已经被T2更新但还没有被提交的字段之后,若T2回滚,T1读取的内容就是临时且无效的


(事务A读取到了事务B已经修改但尚未提交的数据)


②. 不可重复读:对于两个事务T1,T2,T1读取了一个字段,然后T2更新了该字段之后,T1在此读取同一个字段,值就不同了


(事务A内部的相同查询语句在不同时刻读出的结果不一致,不符合隔离性)


③. 幻读:对于两个事务T1,T2,T1从一个表中读取了一个字段,然后T2在该表中插入了一个新的行之后,如果T1再次读取同一个表,就会多出几行


(事务A读取到了事务B提交的新增数据,不符合隔离性)


上一篇:java学习笔记--枚举类(综合网络用法)


下一篇:java枚举类型学习