Postgresql保存点(savepoint)功能

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的保存点功能。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值