十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
SAVEPOINT语句用来实现事务的部分回滚。

为荣昌等地区用户提供了全套网页设计制作服务,及荣昌网站建设行业解决方案。主营业务为成都做网站、网站制作、荣昌网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
SAVEPOINT:SAVEPOINT spnameSAVEPOINT: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的链表如下图所示,其中每个节点记录了
事务为了支持回滚某条 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。