事务:保证数据一致性的重要手段
事务百度上说: 事务(Transaction),一般是指要做的或所做的事情。事务由事务开始(begin transaction)和事务结束(end transaction)之间执行的全体操作组成。
事务操作是一个阶段操作,是一个过程,而非一个节点
start transaction标识事务开始,commit提交事务,将执行结果写入到数据库。如果sql语句执行出现问题,会调用rollback,回滚所有已经执行成功的sql语句。当然,也可以在事务中直接使用rollback语句进行回滚。
autocommit参数是针对连接的,在一个连接中修改了参数,不会对其他连接产生影响。
也就是说,你cmd 后 输入mysql -uroot -pxxxx 后登录的每一个黑窗口属于一个人连接。
ACID特性
- 原子性(Atomicity,或称不可分割性)
- 一致性(Consistency)
- 隔离性(Isolation)
- 持久性(Durability)
Oracle默认的事务隔离级别为READ COMMITTED(读已提交) RC, mysql 默认隔离级别是RR Repeatable Read (可重复读)
mysql 的redo log
脏读,不可重复读,幻读
脏读: 当前事务(A)中可以读到其他事务(B)未提交的数据(脏数据) , 这种现象是脏读。
create table bank_money (id int auto_increment primary key,name varchar(16),money int);
insert into bank_money (id,name,money) values (null,"liuyuanyuan",200);
初始我银行卡账户里面有200块钱
第二个窗口操作如下
在第一个窗口查看
有问题啊,因为二窗口我还未提交,就已经读取到了二窗口未提交的数据,如果这个时候二窗口rollback了呢,回到了200
在rollback 或者commit 之前会读取到未提交的数据,rollback 或者commit 后,就会保持一致。
以上是读未提交的数据
幻读( READ COMMIT):一个事务读取到另一个事务提交的数据(主要表现为某行数据修改--即事务A在操作前先对数据进行读取,事务B对某行数据进行修改,事务A再次读取数据发现数据已不一致)
上面的查是第一次查,初始查
然后对二窗口进行更改
然后对窗口一再进行插入同样的数据发现插入不进去,报1062,已经有这个数据了,但是我查询的时候,却查不到,要知道,窗口二我确实commit提交了,这就是幻读。
如上是幻读的sql 效果展示
幻读,比如我插入id 未2的数据,我先查了一遍,没有啊,张三捷足先登,先插入id 为2的数据,并commit 了,这时候我继续插入,发现不对啊,我没查如果,我刚查的啊,这就是幻读,像产生了幻觉一样,神奇 。
我commit 后,再查一下,发现有人提交了,原来如此,我之前插入不进去 。