postgresql 关闭自动提交
我们知道oracle中sqlplus里面执行dml语句;是需要提交commit;若错了;也可以回滚rollback; 然而在postgresql里面默认是自动提交;执行完就马上提交了,不能回滚,这样容易导致误操作的发生,有没有什么办法避免这个风险呢?当然有,在psql中默认是打开自动提交的,我们可以关闭自动提交。
2. 操作验证
[postgres@oracle2 ~]$ psql -U lottu -d xzfbpsql (9.5.0)Type "help" for help.xzfb=> create table lottu01(id int);CREATE TABLExzfb=> select * from lottu01;id----(0 rows)xzfb=> insert into lottu01 values (1001);INSERT 0 1xzfb=> rollbackxzfb-> ;WARNING: there is no transaction in progressROLLBACKxzfb=> select * from lottu01;id------1001(1 row)
[postgres@oracle2 ~]$ psql -U lottu -d xzfbpsql (9.5.0)Type "help" for help.xzfb=> \set AUTOCOMMIT offxzfb=> insert into lottu01 values (1002);INSERT 0 1xzfb=> commit; --1002此处提交COMMITxzfb=> insert into lottu01 values (1003);INSERT 0 1xzfb=> rollback; --1003回滚了ROLLBACKxzfb=> select * from lottu01;id------10011002(2 rows)
3. 自动关闭提交
如果每次进入psql后都手工设置\set AUTOCOMMIT off比较麻烦,可以把这句设置到.psqlrc文件:
[postgres@oracle2 ~]$ cat .psqlrc\set AUTOCOMMIT off[postgres@oracle2 ~]$
4. 备注
[postgres@oracle2 ~]$ psql -U lottu -d xzfbpsql (9.5.0)Type "help" for help.xzfb=> insert into lottu01 values ('1523');INSERT 0 1xzfb=> insert into lottu01 values ('a1523'); --插入字符串。ERROR: invalid input syntax for integer: "a1523"LINE 1: insert into lottu01 values ('a1523');^xzfb=> insert into lottu01 values (1523); --执行正确的dml语句会报错ERROR: current transaction is aborted, commands ignored until end of transaction blockxzfb=> rollback; --避免下面继续报错ROLLBACKxzfb=> insert into lottu01 values (1523);INSERT 0 1
2. 执行ddl语句;也是需要执行commit,当然也可以rollback
xzfb=> create table t(id int);CREATE TABLExzfb=> select * from t;id----(0 rows)xzfb=> \q[postgres@oracle2 ~]$ psql -U lottu -d xzfbpsql (9.5.0)Type "help" for help.xzfb=> select * from t;ERROR: relation "t" does not existLINE 1: select * from t;^
3. 上面除了设置关闭自动提交;我们也可以通过begin end;去执行。略
作者 : li0924
时间 : 2016-01-22
本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接.
postgresql 关闭自动提交的更多相关文章
- KingbaseES V8R6 ksql 关闭自动提交
背景 用过oracle或mysql的人都知道,做一个dml语句,如果发现做错了,还可以rollback,但在Kingbase ksql 中,如果执行一个dml,没有先运行begin; 的话,一执行完就 ...
- sql小技巧——关闭自动提交,防止误操作
set IMPLICIT_TRANSACTIONS ON--关闭自动提交on 防止误操作,除非显式提交commit后,才会真正提交到数据库中,并且可以随时回滚操作.如下: set IMPLICIT_T ...
- 20181218 - PostgreSQL Auto Commit Guide(自动提交)
20181218 - PostgreSQL Auto Commit Guide 参考官网简介,https://www.postgresql.org/docs/10/ecpg-sql-set-autoc ...
- MysqL自动提交机制的关闭
MysqL在执行一句数据库操作命令的时候,通常都是自动提交的.常用引擎下有两种,分别是MyIsam和InnoDB,MyIsam是不支持事务处理的,但InnoDB支持,但InnoDB在不开启事务处理的情 ...
- JDBC 关闭数据库连接与自动提交【转】
// Jdbc关闭数据库连接时,会隐含一个提交事务的操作 private final static String DB_DRIVER = "oracle.jdbc.driver.Oracle ...
- 14.3.2.2 autocommit, Commit, and Rollback 自动提交 提交和回滚
14.3.2.2 autocommit, Commit, and Rollback 自动提交 提交和回滚 如果自动提交模式被启用,在InnoDB里, 所有的用户活动发生在一个事务里, 每个SQL语句 ...
- Mysql 关闭自动commit
更多内容推荐微信公众号,欢迎关注: 1. 会话级关闭自动提交 mysql> set autocommit=off; Query OK, 0 rows affected (0.00 sec) my ...
- 【PostgreSQL-9.6.3】如何实现非自动提交
我们在使用psql工具操作数据库时,事务是自动提交的.也就是说,当我们执行完一条insert或者delete语句后,在不输入commit情况下,这条语句也是提交的.如果不想自动提交,可以使用以下两种方 ...
- pymssql默认关闭自动模式开启事务行为浅析
使用Python采集SQL Server数据库服务器磁盘信息时,遇到了一个错误"CONFIG statement cannot be used inside a user transacti ...
随机推荐
- javascript设计模式学习之十二——享元模式
一.享元模式的定义及使用场景 享元模式是为了解决性能问题而诞生的设计模式,这和大部分设计模式为了提高程序复用性的原因不太一样,如果系统中因为创建了大量类似对象而导致内存占用过高,享元模式就非常有用了. ...
- iOS 归档
#import <UIKit/UIKit.h> @interface AppDelegate : UIResponder <UIApplicationDelegate> @pr ...
- 在centos安装docker
关闭防火墙 iptables -L systemctl disable firewalld.service systemctl stop firewalld.service 配置代理太麻烦了,建议使用 ...
- 浅谈EasyUI---C#三层架构---
每次写博客,第一句话都是这样的:程序员很苦逼,除了会写程序,还得会写博客!当然,希望将来的一天,某位老板看到此博客,给你的程序员职工加点薪资吧!因为程序员的世界除了苦逼就是沉默.我眼中的程序员大多都不 ...
- SSM框架搭建
http://blog.csdn.net/gebitan505/article/details/44455235/
- linux:什么是linux
1>.linux是一套作业系统(linux就是核心与呼叫这两层),每一种作业系统都是在他专门的硬体机器上面运行的:linux是一个Open Source的作业系统,具有可移植性 2>.li ...
- SQLSERVER:通过sys.tables实现批量删表、快速统计多表记录和
SQLSERVER:通过sys.tables实现批量删表,或者回滚表 begin try drop table #temp10 end try begin catch end catch select ...
- windows下根据端口号杀死进程
Windows不像Linux,Unix那样,ps -ef 查出端口和进程号,然后根据进程号直接kill进程. Windows根据端口号杀死进程要分三步: 第一步 根据端口号寻找进程号 C:\>n ...
- C++ set容器简单用法
set是关联容器,类似于集合,里面的元素不会重复,而且呈现为有序性 常用操作: using namespace std; set<int>:s;1.元素插入:s.insert()2.中序遍 ...
- php4.3.4.4、apache2.0.4.8、mysql 4.0.26、window7 配置过程
apache的安装不需要过程,直接默认安装,下一步 下一步就Ok了. php4的安装: 1 将php-4.0.4-Win32.zip(最新版本4.0.4)解压缩到硬盘的一个目录中,例如解压到E:php ...