-
Notifications
You must be signed in to change notification settings - Fork 57
/
s6.sql
37 lines (26 loc) · 823 Bytes
/
s6.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
-- examples on commit, rollback, savepoint
-- current table status
select *
from service;
-- 1) autocommit
insert into service (name) values ('Example 1');
-- no effect, no pending change
rollback;
-- 2) transaction with explicit termination
begin;
insert into service (name) values ('Example 2');
-- only the current session could see the change
select * from service;
rollback;
-- no effect, no pending change
commit;
-- 3) savepoint for partial rollback
begin;
insert into service (name) values ('Example 3');
savepoint first_step;
insert into service (name) values ('Example 3/B');
rollback to first_step; -- keep first insert, rollback the second one
commit; -- persist Example 3
-- no use: there is no transaction in progress
rollback;
delete from service where service_id > 3;