oracle命令行设置保存点和回滚到保存点

主要说下savepoint(设置保存点)和rollback to(回滚到) 。
该例子是在pl/sql中演示的,navicat的sql界面不支持savepoint和rollback语法。
基本语法:

savepoint a ;  # 设置保存点a
savepoint b ;  # 设置保存点b
rollback to a ;  # 回滚到a
commit ; # 提交

例子演示

准备工作

建表并插入数据(一条数据足矣):

CREATE TABLE T_USER (
  "U_NAME" VARCHAR2(255 BYTE) ,
  "U_SEX" VARCHAR2(255 BYTE) ,
  "U_AGE" NUMBER ,
  "ID" NUMBER
)
insert into t_user (U_NAME, U_SEX, U_AGE, ID)
values ('张三', '男', '18', '1');

过程sql

通过以下sql来模拟保存点和回滚:

select * from t_user; -- 开始的开始 18岁 踌躇满志

Savepoint a; -- a回滚点  18岁
update t_user set u_age ='30' where id='1'; -- 一事无成,已到中年  


Savepoint b; -- b回滚点  30岁
update t_user set u_age ='50' where id='1'; -- 年过半百 仍旧一事无成 知天命了 


Rollback To a; -- 心有不甘,重回18岁
rollback to b; -- 心有不甘,回到30岁
rollback; -- 人生太失败,全部回滚 

commit; -- 算了,人生不可复制  就这样吧
  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值