为什么会有事务:为了保证流程的完整执行。

事务是一组不可被分割的SQL语句的集合,是一组连续的数据库操作,
作为一个单一的工作单元来执行。这一组操作要么全部成功执行,要么全部回滚

最经典的就是银行转账,一个转出,一个收到。

mysql 事务主要用于处理操作量大,复杂度高的数据,
事物处理可以用来维护数据库的完整性,保证成批的sql 语句要么全部执行,要么全部不执行,
事物是用来 管理insert,update,delete语句的。

事务的四个特性

1,原子性
    一个事物中的所有操作,要么全部成功,要么全部失败

2.一致性
    在事务开始之前和结束之后,数据库的完整性没有被破坏,就是说写入
    的数据必须完全符合所有的预设规则,

3.隔离性
    数据库允许多个并发事务同时对其数据进行读写和修改,

4.持久性
    事务处理的结束后,对数据的修改就是永久的,即便系统故障也不会丢失数据。

事务的简单应用

begin ; 
 insert  into  emp values(1,'aaa', 3000);
 insert  into  emp values(2,'bbb', 4000);
 commit ; 开始以  begin 开始,结束以commit  /  rollback 结束
 commit 是提交事务,rollback 是回滚事务。savepoint     // 回滚点,保存点。
 配合 rollback to一起使用,
 savepoint   p1;
 。
 。
 。
 rollback  to  p1;

 

事务的隔离

数据库事务并发时,经常会出现一些问题,会导致:
脏读,不可重复读,幻影读

1.脏读:
    一个事务读取了 同时并发的另一个事务没提交的数据。

2.不可重复读:
    一个事务重复读取之前读取过的数据,后发现读取的数据被另一个
    事务所修改。

3.幻读:
    一个事务重复的读取数据,在获得的数据行中,发现有些数据是其他事务最近操作的数据

处理隔离级别:

read  uncommited      //都允许
 read  commited             //不允许脏读
 repeatable  read        // 只允许幻读        数据库默认
 serializable  read        // 都不允许