欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

事务控制语句

程序员文章站 2022-08-06 10:30:44
语法 事务的四大特性 transaction 事务(交易) (是一组语句组成的主体)DML才有事务,select语句,DDL语句是没有的,它们一旦操作就自动提交 原子性 事务中的语句是一个整体,要么一起成功,要么一起失败就像A转账到B对应的操作简单地看有: - - 这里不能提交,因为不能确保后面的会 ......

语法

commit; 提交(确认操作,写到硬盘上)
rollback;  回滚(回退)
savepoint; 保存点名
rollback  to ;   回滚(回退)到某个点

事务的四大特性

    transaction 事务(交易)

(是一组语句组成的主体)DML才有事务,select语句,DDL语句是没有的,它们一旦操作就自动提交

  • 原子性

事务中的语句是一个整体,要么一起成功,要么一起失败就像A转账到B对应的操作简单地看有:

update account set money=money-5000 
where ano/*账户名*/=’A’ ;

- - 这里不能提交,因为不能确保后面的会成功
- -执行状态保留为a

update account set money=money+5000 
where ano/*账户名*/=’B’ ;

- - 这两个操作要么一起成功,要么一起失败
- -执行状态保留为b

****伪代码:****
if(a&&b){
    commit;
}else{
    ollback;
}

淘宝上买东西和结账也是一样
  • 隔离性

当进行dml操作时,如果没有提交,那对另外一个事务而言数据是不可见的(自己可以看操作后的数据,并且给数据加了锁,不提交自己不能修改,别人也是看不见、不能修改的)

  • 持久性
  • 一致性

保存点  savepoint  保存点名

能打破原子性,允许部分成功,部分失败(大部分情况下要遵循原子性,但有的时候也有要突破的)

insert   /*发送短信*/
update
savepoint  shoufei  /*收费*/
insert   /*收到短信*/
- - 执行状态为c

insert  ...
if(!c){
rollback  to shoufei;
- - 到收费断点后面的语句全部不执行了
}
commit ;  /*一定会提交*/

 

查询一下表的现在的状态:

select * from empn;

事务控制语句

 

传入两个数据并保存点:

insert into empn values(2, niuniu, 2345678);

事务控制语句

 

回退到保存点a,存入的结果是存入一个数据:

rollback to a;
commit;
select * from empn;

事务控制语句