怎么在Postgresql怎么实现一个事务的提交与回滚功能

  介绍

怎么在Postgresql怎么实现一个事务的提交与回滚功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

用过甲骨文或mysql的人都知道在sqlplus或mysql中,做一个dml语句,如果发现做错了,还可以回滚;掉,但在Postgresql的psql中,如果执行一个dml,没有先运行;开始的话,一执行完就马上提交了,不能回滚,这样容易导致误操作的发生,有没有什么办法避免这个风险呢?

当然有,在psql中默认是打开自动提交的,我们可以关闭自动提交,方法如下:

设置\设置自动提交了

测试=#,create  table  test1  (x  int);   CREATE 表   时间:0.593,ms   测试=#,select  *,得到test1;   ,x    ---   (0,行)   时间:0.309,ms   测试=#,回滚;   回滚   时间:1.501,ms   测试=#,select  *,得到test1;   错误:,relation “test1" does  not 存在   1:LINE  select  *,得到test1;   ,,,,,,,,,^   时间:0.376,女士

这儿我们需要注意的是,不同步甲骨文,PG的DDL事务一样是可以回滚的,并没有隐式提交的概念,这儿我们需要注意下

测试=#,\ d ,,,   ,,,List  of 关系   |,Schema  Name  |, Type  |, Owner    - - - - - - - - - - - - - - - - + + - - - - - - - - - - - - - -   |,public  foo  |, table  |猕猴桃   |,public  test  |, table  |猕猴桃   (2,行)

<强>补充:PostgreSQL -事务与提交优化

基本概念

事务事务是数据库管理系统DBMS执行过程中的一个逻辑单元,是一个sql命令组成的序列。

其特点在于,当事务被提交DBMS后,DBMS需要确保所有的操作被完成,如果事务中有的操作没有成功完成,那么所有操作都将回滚,回滚到事务提交之前的状态

属性

事务具有以下四个标准属性

原子性:事务作为一个整体被执行,相当于一个原子

一致性:确保修改前后数据库都满足约束

隔离性:多个事务能并发执行,互不影响

持久性:已被提交的事务对数据库的修改应该永久保存在数据库中

适用场景

某人在商店使用电子货币支付100元,包括以下两个操作:

1。消费者账户减少100元

2。商家账户增加100元

事务的作用就是保证这两个操作要么都发生,要么都不发生,否则可能出现100元凭空消失。

事务控制

使用如下命令控制事务

开始或者开始事务:开始一个事务

提交或者结束事务:提交事务,执行一系列sql

回滚:事务回滚

在开始一个事务后,除非遇到提交或者滚命令,事务才会被执行;

如果还没遇到提交或者回滚,数据库发生异常,也会自动回滚。

注意,事务命令只能用于插入、删除、更新操作,而其他命令,比如建表,删表,会被自动提交。

总结一下:事务需要手动开启,手动提交,而且这种方式能提高操作效率。

实例

假设有如下表

id  |, name  |, age  |, address , |,薪水   - - - - - + - - - - - - - - - - - - - + - - - - - - - - - - - - - - - - - - - - - -   ,1 |,Paul  |, 32, |,加州|,20000   ,2 |,Allen  |, 25, |, Texas ,, |, 15000   ,3 |,Teddy  |, 23, |, Norway , |, 20000   ,4 |,Mark  |, 25, |, Rich-Mond  | 65000年   ,5 |,David  |, 27日,|,Texas ,, |, 85000   ,6 |,Kim , |, 22, |, South-Hall |, 45000   ,7 |,James  |, 24, |, Houston , |, 10000

操作1:开始事务,从表中删除年龄为25的记录,最后用滚撤销所有操作

runoobdb=#,开始;   DELETE 得到COMPANY  WHERE  AGE =, 25;   回滚;

结果如下

id  |, name  |, age  |, address , |,薪水   - - - - - + - - - - - - - - - - - - - + - - - - - - - - - - - - - - - - - - - - - -   ,1 |,Paul  |, 32, |,加州|,20000   ,2 |,Allen  |, 25, |, Texas ,, |, 15000   ,3 |,Teddy  |, 23, |, Norway , |, 20000   ,4 |,Mark  |, 25, |, Rich-Mond  | 65000年   ,5 |,David  |, 27日,|,Texas ,, |, 85000   ,6 |,Kim , |, 22, |, South-Hall |, 45000   ,7 |,James  |, 24, |, Houston , |, 10000

我们发现原表没有任何改变

操作2:开始事务,从表中删除年龄为25的记录,最后用提交提交事务

runoobdb=#,开始;   DELETE 得到COMPANY  WHERE  AGE =, 25;   之前提交;

怎么在Postgresql怎么实现一个事务的提交与回滚功能