0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

GaussDB数据库事务介绍

jf_21561199 来源:jf_21561199 作者:jf_21561199 2023-06-05 16:28 次阅读

前言

随着大数据和互联网技术的不断发展,数据库管理系统的作用越来越重要,实现数据的快速读写以及保证数据的安全性和完整性成为企业在选择数据库技术时最为关注的问题之一。事务是保证数据一致性和完整性的关键机制之一,因此事务管理在数据库技术中占据了极为重要的位置。在这里我们将着重介绍华为云数据库 GaussDB 对事务的支持及管理,包括事务应用场景、事务管理、事务语句、事务隔离、事务监控等内容。

GaussDB 事务的定义及应用场景事务是数据库系统中的一个重要概念,通俗来讲,事务就是一组数据库操作看成一个整体,这个整体要么全部执行成功,要么全部撤销。

事务可以应用在并发访问数据库时,保持数据的一致性。一些常见的应用场景包括转账操作、订单修改、银行交易等。在这些场景中,事务的功能是保证操作的原子性,即要么全部执行成功,数据库的值正确地更新,即处于一个“一致状态”,要么出现异常或系统故障,全部回滚至操作前的状态,以保证数据的准确性和完整性。

wKgaomR9nKuACxJ0AACB84cx4xQ582.png

GaussDB 支持 ACID 事务,即原子性、一致性、隔离性和持久性。在 GaussDB 中,事务是指一组数据库操作,这些操作要么全部成功,要么全部失败。当一个事务提交时,所有的修改都会被永久保存。如果事务失败,则所有的修改都会被回滚,数据库状态会被还原到事务开始前的状态。GaussDB 还支持分布式事务(集群事务),可以涉及到多个节点的事务(本次不做重点介绍)。

原子性(Atomicity):事务是数据库的逻辑工作单位,事务中的操作,要么都做, 要么都不做。

一致性(Consistency):事务的执行结果必须是使数据库从一个一致性状态转到另一 个一致性状态。

隔离性(Isolation):数据库中一个事务的执行不能被其他事务干扰。即一个事务 的内部操作及使用的数据对其他事务是隔离的,并发执行的 各个事务不能相互干扰。

持久性(Durability):事务一旦提交,对数据库中数据的改变是永久的。提交后的 操作或者故障不会对事务的操作结果产生任何影响。

wKgaomR9nKyAa9HEAAD8fNlAD9g628.png

GaussDB 事务的管理事务管理是指在使用数据库系统时,对事务的开启、提交、回滚、保存点、分布式事务等进行管理:

启动事务:GaussDB 通过 START TRANSACTION 和 BEGIN 语法启动事务

设置事务:GaussDB 通过 SET TRANSACTION 或者 SET LOCAL TRANSACTION 语法设置事务

提交事务:GaussDB 通过 COMMIT 或者 END 可完成提交事务的功能,即提交事务的所有操作

回滚事务:回滚是在事务运行的过程中发生了某种故障,事务不能继续执行,系统将事务中对数据库的所有已完成的操作全部撤销

存储过程本身就处于一个事务中,开始调用最外围存储过程时会自动开启一个事务,在调用结束时自动提交或者发生异常时回滚。除了系统自动的事务控制外,也可以使用 COMMIT/ROLLBACK 来控制存储过程中的事务。在存储过程中调用 COMMIT/ROLLBACK 命令,将提交/回滚当前事务并自动开启一个新的事务,后续的所有操作都会在此新事务中运行。

示例 1:启动一个事务

--以默认方式启动事务。START TRANSACTION;SELECT * FROM tpcds.reason;END;

--以默认方式启动事务。BEGIN;SELECT * FROM tpcds.reason;END;

--以隔离级别为 READ COMMITTED,读/写方式启动事务。START TRANSACTION ISOLATION LEVEL READ COMMITTED READ WRITE;SELECT * FROM tpcds.reason;COMMIT;

示例 2:设置事务

--开启一个事务,设置事务的隔离级别为 READ COMMITTED,访问模式为 READ ONLY。START TRANSACTION;SET LOCAL TRANSACTION ISOLATION LEVEL READ COMMITTED READ ONLY;COMMIT;示例 3:支持在 PLSQL 的存储过程内使用 COMMIT/ROLLBACK。

CREATE TABLE EXAMPLE1(COL1 INT);

CREATE OR REPLACE PROCEDURE TRANSACTION_EXAMPLE()ASBEGINFOR i IN 0..20 LOOPINSERT INTO EXAMPLE1(COL1) VALUES (i);IF i % 2 = 0 THENCOMMIT;ELSEROLLBACK;END IF;END LOOP;END;/运行结果:

wKgZomR9nK2AQKeEAABxTDOEgDk714.png

在 GaussDB 中,控制管理事务可以采用两个方法:原子性和隔离性。原子性指一组操作要么全部执行,要么全部不执行。隔离性指一个事务的操作不受其他事务干扰,保证并发执行时数据的一致性。

更多事务管理过程中的使用场景(支持/不支持调用的上下文环境),请参见官网示例:

https://support.huaweicloud.com/centralized-devg-v2-opengauss/devg_03_0713.html

GaussDB 事务语句

事务语句可以看作是在事务中执行的一组语句,常见的事务语句有 insert、update、delete 等。

GaussDB 支持事务语句,事务语句组合成一组原子性、隔离性和一致性的操作。例如,下面的所有查询都包含在同一个事务小片中。如果有任何一个查询失败,整个事务将回滚。以下是事务语句的例子:

BEGIN;SELECT balance FROM account WHERE id = 1 FOR UPDATE;UPDATE account SET balance = balance - 100 WHERE id = 1;COMMIT

wKgaomR9nK2AaaqUAAEbeyXuoKQ088.png

GaussDB 事务隔离

GaussDB 支持的事务隔离级别包括:Read Uncommitted(读未提交)、Read Committed(读提交)、Repeatable Read(重复读)、Serializable(序列化,Serializable 是最高的事务隔离级别,在该级别下,事务串行化顺序执行,可以避免脏读、不可重复读与幻读。但是这种事务隔离级别效率低下,比较耗数据库性能,一般不建议使用)。

语法:

{ SET [ LOCAL ] TRANSACTION|SET SESSION CHARACTERISTICS AS TRANSACTION }{ ISOLATION LEVEL { READ COMMITTED | READ UNCOMMITTED | SERIALIZABLE | REPEATABLE READ }| { READ WRITE | READ ONLY } } [, ...]

Read Uncommitted 隔离级别:最低的隔离级别,它允许提交了但尚未被写入磁盘的事务修改的数据被其他事务所读取。

SET SESSION CHARACTERISTICS AS TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;2. Read Committed 隔离级别:这个级别保证一个事务所见到的数据,要么是提交事务所修改的(已经将数据更新至磁盘),要么就是其他提交事务所修改的。

SET SESSION CHARACTERISTICS AS TRANSACTION ISOLATION LEVEL READ COMMITTED;3. Repeatable Read 隔离级别:保证在一个事务内重复执行的查询返回的结果集是一样的。特别地,在这个级别的情况下,在事务中第一次读表时就会自动获取到所有被查询记录的共享锁,直到关闭连接为止。

SET SESSION CHARACTERISTICS AS TRANSACTION ISOLATION LEVEL REPEATABLE READ;

Serializable 隔离级别:这个级别最高,实现方法是对数据进行锁定,以保证在写操作(INSERT、DELETE 和 UPDATE 等)期间数据不会被访问。

SET SESSION CHARACTERISTICS AS TRANSACTION ISOLATION LEVEL SERIALIZABLE;事务监控是指对事务进行实时的监控,包括事务的状态、执行时间、执行语句、执行结果等。

GaussDB 事务监控

事务监控可以对数据库操作进行记录和追踪,包括事务开始和结束的时间、事务中执行的语句、事务提交或回滚的状态等。可以通过这些信息来监控事务的执行情况,优化性能和调整配置。

华为云数据库 GaussDB 支持 ACID 事务,事务隔离级别支持读已提交、可重复读、序列化三种,并具有分布式事务支持功能。在实际应用中,GaussDB 的事务机制可适用于金融账务、电商订单、物流管理等多种场景。

例如,在电商订单场景中,可以在一个事务中包含插入订单、更新库存、生成支付信息等相关操作,确保这些操作全部成功或全部失败,而不会出现其中某个操作提交,其他操作失败的情况。

而在日常开发中,要注意对事务的合理使用,避免在一个事务中执行过多的操作,尽可能缩小事务的范围,减少事务的执行时间,从而提高系统的并发性能。

事务监控可以对数据库操作进行记录和追踪,包括事务开始和结束的时间、事务中执行的语句、事务提交或回滚的状态等。可以通过这些信息来监控事务的执行情况,优化性能和调整配置。以下是事务监控的示例:

查看活动事务信息(PG_PREPARED_XACTS 视图显示当前准备好进行两阶段提交的事务的信息)

select * from pg_prepared_xacts;

查看事务状态(PG_STAT_ACTIVITY 视图显示和当前用户查询相关的信息。)

select pid, datname, usename, query, query_start, state from pg_stat_activity where state != 'idle' and state != 'idle in transaction';

总结

事务是保证数据一致性和完整性的核心机制之一,对于一个数据库来说,事务的支持和管理是必须的。GaussDB 通过支持手动和自动管理事务、事务隔离级别以及事务监控等功能,满足了企业对数据一致性和完整性的需求。在日常开发中,需要特别注意事务的控制和隔离,以保证事务的正确执行,从而提高数据的可靠性和安全性。

本文介绍到此结束,更多操作可在实际应用中参考官方文档。

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 云计算
    +关注

    关注

    38

    文章

    7354

    浏览量

    135729
  • 数据库
    +关注

    关注

    7

    文章

    3591

    浏览量

    63376
  • 华为云
    +关注

    关注

    3

    文章

    2155

    浏览量

    16809
收藏 人收藏

    评论

    相关推荐

    事务(2)#数据库

    数据库
    未来加油dz
    发布于 :2023年07月18日 17:35:08

    事务(1)#数据库

    数据库
    未来加油dz
    发布于 :2023年07月18日 17:34:33

    事务经历(2)#数据库

    数据库
    学习硬声知识
    发布于 :2023年07月13日 20:22:02

    事务经历(1)#数据库

    数据库
    学习硬声知识
    发布于 :2023年07月13日 20:21:39

    事务恢复(2)#数据库

    数据库
    学习硬声知识
    发布于 :2023年07月13日 20:21:16

    事务恢复(1)#数据库

    数据库
    学习硬声知识
    发布于 :2023年07月13日 20:20:55

    全量通过!华为云 GaussDB 首批完成信通院全密态数据库评测

    100%全量通过!基于全栈创新计算架构的全密态数据库华为云 GaussDB,完成了中国信通院组织的首批“全密态数据库”产品能力评测,标志着 GaussDB 可以为用户
    的头像 发表于 06-27 23:08 267次阅读
    全量通过!华为云 <b class='flag-5'>GaussDB</b> 首批完成信通院全密态<b class='flag-5'>数据库</b>评测

    华为云新一代分布式数据库GaussDB正式发布

        6月,在华为全球智慧金融峰会2023上,华为常务董事、华为云CEO张平安以“一切皆服务,做好金融数字化云底座和使能器”为主题发表演讲,全面介绍了华为云基于全云化底座、分布式数据库
    的头像 发表于 06-16 11:33 861次阅读

    华为云数据库GaussDB:给世界一个更优选择

    数据库国产化进程中,自主能力是产品的根基。以华为云GaussDB数据库为例,代码完全自研。能提供和国际厂商同等的性能和稳定性。目前,华为云GaussDB具备对Oracle等国际一流厂
    的头像 发表于 06-14 23:02 399次阅读
    华为云<b class='flag-5'>数据库</b><b class='flag-5'>GaussDB</b>:给世界一个更优选择

    华为云新一代分布式数据库GaussDB,给世界一个更优选择

    6月7日,在华为全球智慧金融峰会2023上,华为常务董事、华为云CEO张平安以“ 一切皆服务,做好金融数字化云底座和使能器 ”为主题发表演讲, 全面介绍了华为云基于全云化底座、分布式数据库
    的头像 发表于 06-08 17:55 708次阅读

    GaussDB 数据类型介绍

    进行数据类型转换,以满足不同的需求。本文将以示例的形式罗列并介绍一些常见的数据类型转换方法等。  数据类型概念及特点 数据类型是一组值的集合
    的头像 发表于 06-05 16:40 1279次阅读
    <b class='flag-5'>GaussDB</b> <b class='flag-5'>数据</b>类型<b class='flag-5'>介绍</b>

    全量通过!华为云 GaussDB 首批完成信通院全密态数据库评测

    100%全量通过!!! 基于全栈国产自主计算架构的全密态数据库华为云 GaussDB,完成了中国信通院组织的首批“全密态数据库”产品能力评测,标志着 GaussDB 可以为用户
    的头像 发表于 06-05 16:39 972次阅读
    全量通过!华为云 <b class='flag-5'>GaussDB</b> 首批完成信通院全密态<b class='flag-5'>数据库</b>评测

    再识华为云数据库——GaussDB

    前言 华为云数据库 GaussDB 是一款拥有云上高可用,高可靠,高安全,弹性伸缩,一键部署,快速备份恢复,监控告警等关键能力,能为企业提供功能全面,稳定可靠,扩展性强,性能优越的企业级数据库服务
    的头像 发表于 06-05 16:38 936次阅读
    再识华为云<b class='flag-5'>数据库</b>——<b class='flag-5'>GaussDB</b>

    GaussDB存储过程介绍

    华为云数据库 GaussDB 是一款高性能、高安全性的云原生数据库,在数据库领域处于领先地位。而在 GaussDB 中,存储过程是一个不容忽
    的头像 发表于 06-05 16:30 444次阅读
    <b class='flag-5'>GaussDB</b>存储过程<b class='flag-5'>介绍</b>

    GaussDB数据库存储过程介绍

    华为云数据库 GaussDB 是一款高性能、高安全性的云原生数据库,在数据库领域处于领先地位。而在 GaussDB 中,存储过程是一个不容忽
    的头像 发表于 05-30 09:52 731次阅读