关闭

Postgresql保存点(savepoint)功能

标签: postgresql
443人阅读 评论(0) 收藏 举报
分类:

PG数据库保存点

PG数据库支持保存点(savepoint)功能,在比较大的事务中,可以把执行过程分为几个步骤,每个步骤执行完成后创建一个保存点,后续步骤执行失败时,可回滚到之前的保存点,而不必回滚整个事务。

  • 示例如下:
TEST=# select * from test;
 id | value1 | value2
----+--------+--------
  1 |      1 |      1
  2 |      2 |      2
  3 |      3 |      3
  4 |      4 |      4
  5 |      5 |      5
  6 |      6 |      6
  7 |      7 |      7
  8 |      8 |      8
  9 |      9 |      9
(9 行记录)

TEST=# begin;
BEGIN
TEST=# update test set value1=10 where id=1;
UPDATE 1
TEST=# update test set value1=10 where id =2;
UPDATE 1
TEST=# savepoint mysp1;
SAVEPOINT
TEST=#
TEST=# update test set value1=10 where id=3;
UPDATE 1
TEST=# select * from test;
 id | value1 | value2
----+--------+--------
  4 |      4 |      4
  5 |      5 |      5
  6 |      6 |      6
  7 |      7 |      7
  8 |      8 |      8
  9 |      9 |      9
  1 |     10 |      1
  2 |     10 |      2
  3 |     10 |      3
(9 行记录)

TEST=# rollback to savepoint mysp1;
ROLLBACK
TEST=# select * from test;
 id | value1 | value2
----+--------+--------
  3 |      3 |      3
  4 |      4 |      4
  5 |      5 |      5
  6 |      6 |      6
  7 |      7 |      7
  8 |      8 |      8
  9 |      9 |      9
  1 |     10 |      1
  2 |     10 |      2
(9行记录)

TEST=# commit;
COMMIT
TEST=# select * from test;
 id | value1 | value2
----+--------+--------
  3 |      3 |      3
  4 |      4 |      4
  5 |      5 |      5
  6 |      6 |      6
  7 |      7 |      7
  8 |      8 |      8
  9 |      9 |      9
  1 |     10 |      1
  2 |     10 |      2
(9 行记录)

如上,执行两次update操作,分别把id=1 和 id=2的两条数据的value1更新为10。
然后创建一个savepoint mysp1。
再执行update语句把id=3的value1更新为10.
此时查询全部数据可以看到,id为1,2,3的三条数据的value1都被更新为了10.
执行rollback操作,回滚到保存点mysp1,查询全部数据,可以看到只有id=3的update操作被回滚,但是id=1,2的数据没有被回滚。
执行commit操作提交整个事务,再次查询全部数据,依然是id=1,2的数据被更新,id=3的数据未更新。
这就是PG的保存点功能。

1
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:10890次
    • 积分:274
    • 等级:
    • 排名:千里之外
    • 原创:13篇
    • 转载:1篇
    • 译文:0篇
    • 评论:0条
    文章分类