为什么会有事务:为了保证流程的完整执行。
事务是一组不可被分割的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 // 都不允许