PG事务、事务隔离级别、并发控制

事物与并发控制

##################################
事物是关系型数据库中非常重要的概念。
并发通常能带来更大的吞吐量、资源利用率和更好的性能。

当多个事物并发执行时,即使每个单独的事物都正确的执行,数据库的一致性可能被破坏。为了控制并发事物之间的相互影响,解决并发可能带来的资源竞争,及数据不一致的问题。

数据库的并发系统引入了基于锁的并发控制机制和基于多版本的并发控制机制MVCC。

#################################(非常重要。数据库管理员和开发者都应该了解)
pg的事物、MVCC的基本知识。工作细节和原理

1、事务4个重要特性
原子性、一致性、隔离性、持久性

原子性:就是事务执行,要么执行所有的操作,要么全部执行,要么不全部执行

一致性:执行事务时,数据库从一个状态变更为另外一个状态

隔离性:即使每个事务都保持一致性、原子性,但是执行并发时,由于他们的操作以人们不希望的方式交叉执行,就会导致不一致的情况,确保事务与事务并发执行时。每个事务都感觉不到其他事务在并发执行。

持久性:一个事务执行完成后,即使数据库发生故障,但是数据库的更改都永久的保存在数据库中,即永久保存在磁盘中。


2、并发引起的现象

如果所有的事务都是按照顺序执行,所有的事务执行时间内没有其他事务的交叉执行,不会发生事务并发现象。
但是一个事务执行,另外一个事务也在执行,并且产生了并发,会引发以下的现象。

2.1 脏读
    当第一个事务读取了第二个事务中已经修改,但是未提交的

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/813677.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

专栏开篇 | 虚拟直播软件的技术架构与应用场景分析

系列文章 技术探索 特征点检测 如何在前端项目中使用opencv.js | opencv.js入门如何使用tensorflow.js实现面部特征点检测tensorflow.js 如何从 public 路径加载人脸特征点检测模型tensorflow.js 如何使用opencv.js通过面部特征点估算脸部姿态并绘制示意图tensorflow.js 使用…

GB/T 28181标准中的错误码,国标28181中可能出现的SIP协议相关的错误码及其含义

目录 一、GB/T 28181标准介绍 (一)概述 (二)关键内容和特点 1. 系统架构: 2. 设备接入: 3. 网络通信: 4. 业务功能: 5. 安全保护: 6. 平台管理: &a…

【C语言】字符串函数和内存函数及其模拟实现

文章目录 前言 一、常见字符串库函数1.strlen函数2.长度不受限制的字符串函数2.1 strcpy2.2 strcat2.3 strcmp 3.长度受限制的字符串函数3.1 strncpy3.2 strncat3.3 strncmp 二、字符串查找函数strstrstrtok 三、strerror函数四、内存操作函数1.memcpy2.memmove3.memcmp 五、字…

力扣刷题 二叉树层序遍历相关题目II

NO.116 填充每个节点的下一个右侧节点指针 给定一个 完美二叉树 ,其所有叶子节点都在同一层,每个父节点都有两个子节点。二叉树定义如下: struct Node {int val;Node *left;Node *right;Node *next; } 填充它的每个 next 指针,…

jieba分词的应用

使用jieba分词的目的主要是将连续的中文文本切分成独立的词汇单元,以便进行后续的文本分析和处理。jieba分词是中文文本处理中的一个重要步骤,特别适用于中文等没有明显词汇边界的语言。 jieba分词的应用场景非常广泛,包括但不限于以下几个方…

iOS开发如何更改xcode中的Apple ID

在Xcode中更改Apple ID是一项常见的任务,尤其是当你需要切换到另一个开发者账号或者团队时。下面是一个简单的步骤指南,帮助你更改Xcode中的Apple ID: 步骤一:退出当前的Apple ID 1.打开Xcode应用程序。 2.在菜单栏中,…

外贸公司应该怎么选择企业邮箱?哪个企业邮箱最好?

外贸公司业务的特殊性需要他们频繁进行跨国的沟通交流,那么外贸公司应该如何选择适合的企业邮箱呢?首先,传输邮件的稳定安全是前提,另外由于沟通多是国外客户,邮件的翻译也成为外贸公司企业邮箱的刚需。小编今天就详细…

冒泡排序算法实现步骤

算法实现的过程: 1. 定义问题: - 算法是用来解决某一特定计算问题的方法步骤。例如,对于排序问题,我们需要一个算法对一组无序的整数进行排序。 2. 设计算法: - 冒泡排序是一种基础的排序算法。它的设计思路是…

Android 应用启动过程

Android应用的完全启动过程 用户点击应用图标后,Android应用的完全启动过程包括以下步骤: 启动器图标点击:用户点击应用程序的图标,触发启动器(Launcher)加载应用程序的入口Activity。 启动器加载&#x…

代码随想录训练营18day-二叉树7

一、530.二叉搜索树的最小绝对差 利用二叉搜索树的有序性,每一层遍历时候,最小差一定是在相邻的两个节点间产生的,因此做递归的时候,记录一个pre和cur节点,用来比较差值,迭代更新时候,记录最小…

ARMv8-A架构下的外部debug模型之外部调试事件(external debug events)概述

外部调试器与处理器之间的握手与external debug events 一,External Debug的使能二,外部调试器和CPU之间的握手三,外部调试事件 External debug events1. External debug request event2. Halt instruction debug event3. Halting step debug…

docker部署安装整理

centos下安装部署docker 在CentOS下部署Docker,你需要按照以下步骤进行操作: 更新系统: 首先,确保你的CentOS系统是最新的。打开终端,并运行以下命令来更新你的系统: sudo yum update -y安装所需的软件包…

[C++/Linux] UNIX域函数

目录 一.什么是UNIX域套接字? 二.如何使用UNIX域函数进行套接字编程? 三.利用socketpair函数进行文件描述符传递 3.1 socketpair函数 3.2 实例 3.3 补充消息结构知识 一.什么是UNIX域套接字? Unix域套接字(Unix Domain Socke…

程序“猿”高阶函数

高阶函数是函数式编程的一个核心概念,它提供了强大的抽象能力,使得代码更加简洁和模块化。正如你所提到的例子,高阶函数可以接受其他函数作为参数,或者返回一个函数。这种特性让它们在处理列表操作、事件处理、异步编程等场景中非…

【力扣一刷】代码随想录day38(动态规划part1:509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼)

目录 【动态规划理论基础】 【509. 斐波那契数】简单题 方法一 用额外的数组存储每个状态 方法二 用2个遍历存储前两个状态(减小空间复杂度) 【70. 爬楼梯】简单题 【746. 使用最小花费爬楼】简单题 【动态规划理论基础】 1、定义:英…

代码随想录算法训练营第四十二天|leetcode121、122题

一、leetcode第121题 本题要求买卖股票一次获取最大利润,设置dp数组,其中dp[i][0]的含义是第i天持有股票的最大利润,dp[i][1]的含义是第i天不持有股票的最大利润,可得递推公式为dp[i][0]max(dp[i-1][0],-prices[i]),d…

A15 STM32_HAL库函数 之 FLASH扩展驱动 所有函数的介绍及使用

A15 STM32_HAL库函数 之 FLASH扩展驱动 所有函数的介绍及使用 1 FLASH扩展驱动 预览1.1 HAL_FLASHEx_Erase1.2 HAL_FLASHEx_Erase_IT1.3 HAL_FLASHEx_OBErase1.4 HAL_FLASHEx_OBProgram1.5 HAL_FLASHEx_OBGetConfig1.6 HAL_FLASHEx_OBGetUserData 该文档修改记录:总…

【从浅学到熟知Linux】环境变量详谈(含使用程序获取环境变量的3种方法、如何查看环境变量)

🏠关于专栏:Linux的浅学到熟知专栏用于记录Linux系统编程、网络编程及数据库等内容。 🎯每天努力一点点,技术变化看得见 文章目录 环境变量基本概念查看环境变量的方法环境变量相关命令环境变量组织方式及获取环境变量的3种方法验…

Cesium.js--》探秘Cesium背后的3D模型魔力—加载纽约模型

今天简单实现一个Cesium.js的小Demo,加强自己对Cesium知识的掌握与学习,先简单对这个开源库进行一个简单的介绍吧! Cesium 是一个开源的地理空间可视化引擎,用于创建基于 Web 的三维地球应用程序。它允许开发人员在网页上呈现高度…

Java基础第十一课——类与对象(2)

由于类与对象这一部分的知识点很多,而且操作方法也有很多,所以这次将继续深入讨论一下关于类与对象中方法传参、方法重载、构造方法以及this关键字使用方面的知识。 一、方法传参 1.return关键字 return关键字作用 作用场景:方法内 作用…