• 事务时需要在同一处理单元中执行的一系列更新处理的集合。通过使用事务,可以对数据库中的数据更新处理的提交和取消进行管理。
  • 事务处理的终止指令包括COMMIT(提交处理)和ROLLBACK(取消处理)两种。
  • DBMS的事务具有原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)四种特性,统称为ACID特性。

举个例子,比如你在一个销售部门工作,这个时候领导分配给你一个工作:

“zifeiy,我们决定把运动T恤的销售单价下调100元,同时把T恤衫的销售单价上浮100元,麻烦你去更新一下数据库。”

那么其实这么一个任务中时包含两个步骤的:

  1. 将运动T恤的销售单价降低100元:
UPDATE Product
SET sale_price = sale_price - 100
WHERE product_name = '运动T恤';
  1. 将T恤衫的销售单价上浮100元:
UPDATE Product
SET sale_price = sale_price + 100
WHERE product_name = 'T恤衫';

上述连个操作要作为同一个处理单元执行。

也就是说:“要么都执行,要么都不执行。”

遇到这种需要在同一个处理单元中执行一系列更新操作的情况,一定要使用事务来进行处理。

创建事务

如果想在DBMS中创建事务,可以按照如下语法结构编写SQL语句:

事务开始语句;

DML语句1;
DML语句2;
DML语句3;
…… 事务结束语句(COMMIT或者ROLLBACK);

使用事务开始语句和事务结束语句,将一系列DML语句(INSERT/UPDATE/DELETE语句)括起来,就实现了一个事务处理。

事务的开始语句在不同的DBMS中有区别:

  • SQL Server、PostgreSQL:BEGIN TRANSACTION
  • MySQL:START TRANSACTION
  • Oracle、DB2: 无

在PostgreSQL中更新商品信息的事务:

BEGIN TRANSACTION;

    -- 将运动T恤的销售单价降低100元
UPDATE Product
SET sale_price = sale_price - 100
WHERE product_name = '运动T恤';
-- 将T恤衫的销售单价上浮100元
UPDATE Product
SET sale_price = sale_price + 100
WHERE product_name = 'T恤衫'; COMMIT;
  • COMMIT:提交处理

    • COMMIT的流程 = 直线进行
  • ROLLBACK:取消处理
    • ROLLBACK的流程 = 掉头回到起点

事务回滚的例子:

BEGIN TRANSACTION;

    -- 将运动T恤的销售单价降低100元
UPDATE Product
SET sale_price = sale_price - 100
WHERE product_name = '运动T恤';
-- 将T恤衫的销售单价上浮100元
UPDATE Product
SET sale_price = sale_price + 100
WHERE product_name = 'T恤衫'; ROLLBACK;

上述事务处理执行之后,表中的数据不会发生任何改变。这是因为执行最后一行的ROLLBACK之后,所有的处理都被取消了。因此,回滚执行起来就无需像提交时那样小心翼翼了(即使是想要提交的情况,也只需要重新执行事务就可以了)。

PostgreSQL学习笔记——事务的更多相关文章

  1. MySQL学习笔记-事务相关话题

    事务机制 事务(Transaction)是数据库区别于文件系统的重要特性之一.事务会把数据库从一种一致状态转换为另一个种一致状态.在数据库提交工作时,可以确保其要么所有修改都已经保存了,要么所有修改都 ...

  2. Postgresql学习笔记

    一:数据类型 主要有三大类以及其他一些杂项类型: 数值型.字符型.日期型. 数值型: 名称 描述 存储大小 范围 smallint 存储整数,小范围 2字节 -32768 至 +32767 integ ...

  3. postgresql学习笔记--基础篇 - copy

    1. psql 导入/导出数据 psql支持文件数据导入到数据库,也支持数据库表数据导出到文件中. COPY命令和\copy 命令都支持这两类操作,但两者有如下区别: COPY 命令是SQL命令,\c ...

  4. postgresql学习笔记--基础篇 -psql工具

    --创建用户 CREATE ROLE pguser WITH ENCRYPTED PASSWORD 'pguser'; --创建表空间目录 mkdir -p /database/pg10/pg_tbs ...

  5. postgresql学习笔记--基础篇

    1. 客户端程序和服务器端程序 1.1 客户端程序 Command Example Describe clusterdb clusterdb -h pghost1 -p 1921 -d mydb Cl ...

  6. PostgreSQL学习笔记——摘要

    因为PostgreSQL和MySQL.DB2等数据库均遵循SQL语法,所以这篇随笔仅记录一些PostgreSQL中和别的数据库有差别或之前学习中遗漏的地方,以及一些我觉得比较重点的地方. 通过psql ...

  7. PostgreSQL学习笔记(二)-安装pgAdmin

    继上篇安装PostgreSQL后,我们需要安装一个PostgreSQL的图形化管理工具. pgadmin管理工具 创建Python的虚拟环境 cd /root/venv python -m venv ...

  8. PostgreSQL学习笔记(一)-安装PostgreSQL

    PostgreSQL官网:https://www.postgresql.org/docs/11/index.html1.如何安装2.如何修改配置文件3.如何设置自动启动4.如何修改数据用户密码 本文环 ...

  9. jsp+postgresql学习笔记(1)用户登录与注册

    前期准备: tomcat的安装与配置(略) jdk的安装与配置(略) eclipse软件安装与配置(略) webstrom软件或IDEA的安装与配置(大概用了IDEA就不需要eclipse了,但是怎么 ...

随机推荐

  1. html学习 菜鸟

    1HTML 不是一种编程语言,而是一种标记语言 2只有 <body>区域才会在浏览器中显示. 3<!DOCTYPE>声明有助于浏览器中正确显示网页.doctype 声明是不区分 ...

  2. 随便写一个c++类

    为了让代码更贴合实际项目需要,我们分别用xxx.h文件,xxx.cpp文件来包含类的定义,类的声明和类的调用部分,实验平台vs2010 mycoach.h文件 #pragma once #includ ...

  3. jaxa技术2

    XStream 1. 什么作用  * 可以把JavaBean转换为(序列化为)xml 2. XStream的jar包  * 核心JAR包:xstream-1.4.7.jar:  * 必须依赖包:xpp ...

  4. QSlider 样式

    https://doc.qt.io/archives/qt-4.8/stylesheet-examples.html #if 0 m_sliderVoice->setStyleSheet(&qu ...

  5. MyBatis模糊查询和多条件查询

    一.ISmbmsUserDao层 //根据姓名模糊查询 public List<Smbms> getUser(); //多条件查询 public List<Smbms> get ...

  6. zabbix的日志监控

    前提条件是该日志文件对于启动zabbix agent进程的用户开启了可读权限,而且该日志的路径对该用户开方x权限,让能取到这个日志文件 第一个参数可以不用引号,前提是zabbix用户可以进入文件路径, ...

  7. SD六校联考二轮

    数据差评 D1T1 string 直接模拟 每次 string_u = const_string + string_v 理论得分 30 实际可得 100 D2T1 n^2 理论得分 30 实际可得 1 ...

  8. 【概率论】5-2:伯努利和二项分布(The Bernoulli and Binomial Distributions)

    title: [概率论]5-2:伯努利和二项分布(The Bernoulli and Binomial Distributions) categories: - Mathematic - Probab ...

  9. syniverse是一家怎样的公司

    syniverse是一家怎样的公司?(详见问题描述)? 李超   核心业务当然是国际漫游了.简单来说就是做全球各个运营商之间的hub. 打个比方说,一家运营商A做通信,它的覆盖范围肯定是有限的(比如中 ...

  10. chrome 截取整个网页