Postgresql 事务的提交与回滚
2016-09-29 09:18
513 查看
原博客 http://blog.csdn.net/kiwi_kid/article/details/50881919
用过oracle或mysql的人都知道在sqlplus或mysql中,做一个dml语句,如果发现做错了,还可以rollback;掉,但在PostgreSQL的psql中,如果执行一个dml,没有先运行begin;的话,一执行完就马上提交了,不能回滚,这样容易导致误操作的发生,有没有什么办法避免这个风险呢?当然有,在psql中默认是打开自动提交的,我们可以关闭自动提交,方法如下:
设置\set AUTOCOMMIT off
test=# create table test1 (x int);
CREATE TABLE
Time: 0.593 ms
test=# select * from test1;
x
---
(0 rows)
Time: 0.309 ms
test=# rollback;
ROLLBACK
Time: 1.501 ms
test=# select * from test1;
ERROR: relation "test1" does not exist
LINE 1: select * from test1;
^
Time: 0.376 ms
这儿我们需要注意的是,不同步Oracle,PG的DDL事务一样是可以回滚的,并没有隐式提交的概念,这儿我们需要注意下
test=# \d
List of relations
Schema | Name | Type | Owner
--------+------+-------+-------
public | foo | table | kiwi
public | test | table | kiwi
(2 rows)
用过oracle或mysql的人都知道在sqlplus或mysql中,做一个dml语句,如果发现做错了,还可以rollback;掉,但在PostgreSQL的psql中,如果执行一个dml,没有先运行begin;的话,一执行完就马上提交了,不能回滚,这样容易导致误操作的发生,有没有什么办法避免这个风险呢?当然有,在psql中默认是打开自动提交的,我们可以关闭自动提交,方法如下:
设置\set AUTOCOMMIT off
test=# create table test1 (x int);
CREATE TABLE
Time: 0.593 ms
test=# select * from test1;
x
---
(0 rows)
Time: 0.309 ms
test=# rollback;
ROLLBACK
Time: 1.501 ms
test=# select * from test1;
ERROR: relation "test1" does not exist
LINE 1: select * from test1;
^
Time: 0.376 ms
这儿我们需要注意的是,不同步Oracle,PG的DDL事务一样是可以回滚的,并没有隐式提交的概念,这儿我们需要注意下
test=# \d
List of relations
Schema | Name | Type | Owner
--------+------+-------+-------
public | foo | table | kiwi
public | test | table | kiwi
(2 rows)
相关文章推荐
- Postgresql 事务的提交与回滚
- PostgreSQL之 事务的提交与回滚
- 关于SAP的事务提交和回滚(LUW)
- 详解Java的JDBC API中事务的提交和回滚
- 关于SAP的事务提交和回滚(LUW)
- 事务,提交,回滚,保存点,表的锁定,隐式锁,显示锁,写锁,读锁,排他锁,共享锁
- Oracle(二) – 隐式的事务提交或回滚动作
- ssm手动提交事务或回滚事务
- redo和undo事务提交和回滚
- java 事务提交/回滚
- 关于SAP的事务提交和回滚(LUW)
- mysql事务的提交和回滚
- oracle 数据库事务,提交,回滚,保存点,表的锁定,隐式锁,显示锁,写锁,读锁,排他锁,共享锁
- 关于SAP的事务提交和回滚(LUW)
- Spring事务之事务回滚、清理及提交
- JDBC对事务的使用(包括自动提交,回滚等知识)
- spring框架多个数据库操作需统一提交事务回滚机制解析以及解决办法
- 使用事务实现--转账问题:从0001账户转1000块到0002账户。打开"隐式事务":设置为开,删除表中数据,回滚!(默认情况为关,如果打开了则不自动提交,学要手动提交)
- 对ORACLE 已提交的事务进行回滚之详细版和操作版