SAVEPOINT
语句用来实现事务的部分回滚。
SAVEPOINT
:SAVEPOINT spname
SAVEPOINT
:ROLLBACK [WORK] to [SAVEPOINT] spname
参数 |
描述 |
---|---|
spname |
指定 |
假设一个事务执行了如下语句:
sql_no |
语句 |
分区 |
---|---|---|
1 |
update... |
p1, p4 |
savepoint sp1 |
||
2 |
update... |
p2, p4 |
3 |
update... |
p3, p5 |
savepoint sp2 |
||
4 |
update... |
p1, p3, p6 |
5 |
update... |
p1, p5 |
savepoint sp3 |
||
6 |
select... |
|
7 |
update... |
p5, p6 |
savepoint sp4 |
用户在提交事务之前可以创建SAVEPOINT
,需要根据SAVEPOINT
创建的顺序,将事务的SAVEPOINT
串成链表。以上事务包含了 7 条 SQL 和 4 个SAVEPOINT
,记录SAVEPOINT
的链表如下图所示,其中每个节点记录了<spname, sql_no>
的映射关系:
事务为了支持回滚某条 SQL 之后的所有修改,需要将每条语句涉及的参与者以及对应的 sql_no
记录下来,以上事务执行了 7 条 SQL,涉及 p1~p6 共 6 个分区:
SAVEPOINT
链表查询spname
对应的sql_no
假设用户执行ROLLBACK to SAVEPOINT sp2
,根据savepoint链表查询到 sp2 对应的sql_no
为 3。sql_no
对应的分区根据事务参与者列表查询到sql_no
大于 3 的语句操作的分区涉及 p1、p3、p5、p6。sql_no
大于 3 的操作信息从事务参与者列表中删除,由于 p6上的所有修改都被回滚掉,因此 p6 可以从参与者列表中删除。
ROLLBACK to SAVEPOINT sp2
成功后,系统会删除 sp3 和 sp4 的SAVEPOINT,不允许再回滚到 sp3 和 sp4。
VARCHAR数据类型用于存储可变长度的字符串。当您创建VARCHAR数据类型的列时,您必须为VARCHAR列指定最大长度。尽管...
诊断功能是用来帮助用户了解目前集群租户的负载及健康情况,并为用户提供了绑定执行计划的功能。默认展示最近一小时的租户性能数...
OceanBase 迁移服务(OceanBase Migration Service,OMS)连接的两端分别是待迁移的源业务数据库和目标端 OceanBase 数据库。下...
MERGE 算子用于将源表中的数据行以更新或插入的方式合并到目标表中。OceanBase 数据库支持的 MERGE 算子包括 MERGE 和 MULTI PAR...
您创建并保存的连接配置会直接展示在 OceanBase 开发者中心(OceanBase Developer Center,ODC)首页的连接管理页签。连接管理页...