当前位置: 首页 > news >正文

数据库事务ACID介绍

一、ACID简介

ACID,是指数据库管理系统(DBMS)在增删改数据的的过程中,为保证事务(transaction)的准确性,可靠性等,所必须具备的四个特性:原子性(atomicity,或称不可分割性)、一致性(consistency)、隔离性(isolation,又称独立性)、持久性(durability)。

事务(transaction) 由一系列数据库操作组成的一个完整的逻辑过程。例如银行转帐,从原账户扣除金额,以及向目标账户添加金额,这两个数据库操作的总和,构成一个完整的逻辑过程,不可拆分。这个过程被称为一个事务,并具有ACID特性。

二、四大特性详解

  • 原子性(atomicity):一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。
  • 一致性(consistency):一致性关注数据的可见性,中间状态的数据对外部不可见,只有最初状态和最终状态的数据对外可见。
  • 隔离性(isolatio):数据库在设计之初,一般都会考虑事务的并发性,不会只让数据库在同一时间只处理一个事务,这样效率会很低,数据库一般会允许多个并发事务同时对其数据进行读写和修改,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。MYSQL数据库中的事务隔离分为不同级别,包括读未提交(Read uncommitted)、读提交(read committed)、可重复读(repeatable read)和串行化(Serializable)。当事务访问同一资源的时候,如果是增删改的操作,会对资源进行上锁,这些锁要嘛造成死锁,涉及的相关事务会失败回滚,要嘛是先上锁的事务先完成,后续的事务会等前一个事务完成之后再继续执行。如果是读写事务同时访问同一资源,这就会涉及到隔离性级别。
  • 持久性(durability):事务提交处理结束后,对数据的修改就是永久的,即便后续系统故障修改的数据也不会丢失。

相关文章:

数据库事务ACID介绍

一、ACID简介 ACID,是指数据库管理系统(DBMS)在增删改数据的的过程中,为保证事务(transaction)的准确性,可靠性等,所必须具备的四个特性:原子性(atomicity&a…...

SM8650 qcxserver.c STRM_Initialize

STRM_Initialize streammanager 初始化流程 目录 STRM_Initialize Gptp::Init Config::Init SensorManager::Init SensorPlatform::SensorPlatformInit SensorManager::LoadSensorLib SensorManager::OpenSensorLib SensorManager::DetectAll SensorManager::DetectHandlerT…...

适配器模式-java实现

意图 复用已经存在的接口,与所需接口不一致的类。即将一个类(通常是旧系统中的功能类),通过适配器转化成另一个接口的实现。(简单来说,就是复用旧系统的功能,去实现新的接口) 我们举…...

【elasticSearch系】3.完整搭建详尽版elk

话不多说,我们先看下经典的elk 是由哪些组件搭建组合起来的 elasticsearch和kibana搭建 可以查看之前我们搭建elasticsearch和kibana 的这篇文章 logstash搭建 为了和之前我们搭建elasticsearch和kibana版本保持一致,这里我们还是选择7.17.3 下载地址 点击下载,这里为了…...

代码随想录day04

24. 两两交换链表中的节点 ● 力扣题目链接 ● 给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。 ● 你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。 思路 ● 使用迭代的方法,分析交换逻辑即可 ○ …...

[Realtek] WPA_SUPPLICANT + WPA_CLI使用指南

开启wpa_supplicant wpa_supplicant –Dnl80211 -iwlan0 -c ./wpa.conf –B 或者 wpa_supplicant -Dwext -iwlan0 -c ./wpa.conf -B 扫描AP wpa_cli -p/var/run/wpa_supplicant scan 查看AP扫描结果 wpa_cli -p/var/run/wpa_supplicant scan_results 连接到热点 OPEN…...

# ⛳ Docker 安装、配置和详细使用教程-Win10专业版

目录 ⛳ Docker 安装、配置和详细使用教程-Win10专业版🚜 一、win10 系统配置🎨 二、Docker下载和安装🏭 三、Docker配置🎉 四、Docker入门使用 ⛳ Docker 安装、配置和详细使用教程-Win10专业版 🚜 一、win10 系统配…...

Linux 教程

目录 Linux 教程 内核引导 运行init 运行级别 系统初始化 Linux 系统目录结构 Linux 教程 Lin...

图论——最短路算法

引入&#xff1a; 如上图&#xff0c;已知图G。 问节点1到节点3的最短距离。 可心算而出为d[1,2]d[2,3]112,比d[1,3]要小。 求最短路径算法&#xff1a; 1.Floyd(弗洛伊德) 是一种基于三角形不等式的多源最短路径算法。边权可以为负数 表现为a[i,j]a[j,k]<a[i,k]。 …...

在项目中增加网络加载需要考虑什么?

1、下载器 网络加载的第一步肯定是下载&#xff0c;那么选择一个合适的下载器是十分重要的&#xff0c;这个下载器最好支持什么功能&#xff1f; 多线程下载&#xff08;同时需要服务端支持&#xff0c;下载时可指定range&#xff09; 断点续传 通用性&#xff08;其他位置也…...

阿里云服务器部署RabbitMQ流程

阿里云百科分享使用阿里云服务器部署RabbitMQ流程&#xff0c;RabbitMQ是实现了高级消息队列协议&#xff08;AMQP&#xff09;的开源消息代理软件&#xff0c;用于在分布式系统中存储转发消息&#xff0c;有良好的易用性、扩展性和高可用性。本文介绍如何通过ECS实例部署Rabbi…...

青大数据结构【2014】

一、单选 二、简答 为了解决顺序队列的假溢出问题&#xff0c;提出了循环队列&#xff0c;即把存储队列的表从逻辑上看成一个环 判别队列空和满有三种方法&#xff1a; 1&#xff09;采用计数器判别&#xff0c;空时&#xff0c;计数器为0&#xff1b;满时&#xff0c;计数器…...

Ansible Playbook快速部署一主多从MySQL集群

部署目标&#xff1a; 1、快速部署一套一主两从的mysql集群 2、部署过程中支持交互式定义安装目录及监听端口号 部署清单目录结构&#xff1a; rootmaster:/opt/mysql# tree . . ├── group_vars │ └── all.yml ├── hosts ├── mysql.yml └── roles└── mys…...

27.Netty源码之FastThreadLocal

highlight: arduino-light FastThreadLocal FastThreadLocal 的实现与 ThreadLocal 非常类似&#xff0c;Netty 为 FastThreadLocal 量身打造了 FastThreadLocalThread 和 InternalThreadLocalMap 两个重要的类。下面我们看下这两个类是如何实现的。 FastThreadLocalThread 是对…...

linux下离线安装docker

linux下离线安装docker 一、安装docker Docker 官网离线安装文档 https://docs.docker.com/engine/install/binaries/ 整理步骤如下&#xff1a; 官网下载 docker 安装包&#xff0c;地址为 https://download.docker.com/linux/static/stable/&#xff0c;如果是x86就选择x…...

SQL server 异地备份数据库

异地备份数据库 1.备份服务器中设置共享文件夹 2.源服务器数据库中添加异地备份代理作业 EXEC sp_configure show advanced options, 1;RECONFIGURE; EXEC sp_configure xp_cmdshell, 1;RECONFIGURE; declare machine nvarchar(50) 192.168.11.10 --服务器IP declare pa…...

高并发系统设计要点

在系统设计时&#xff0c;如果能预先看到一些问题&#xff0c;并在设计层面提前解决&#xff0c;就会给后期的开发带来很大的便捷。相反&#xff0c;有缺陷的架构设计可能会导致后期的开发工作十分艰难&#xff0c;甚至会造成“推倒重来”的情形。因此&#xff0c;在系统设计阶…...

Redis 拒绝服务漏洞(CVE-2023-28856)修复处理

一、漏洞描述 Redis Labs Redis是美国Redis Labs公司的一套开源的使用ANSI C编写、支持网络、可基于内存亦可持久化的日志型、键值&#xff08;Key-Value&#xff09;存储数据库&#xff0c;并提供多种语言的API。 Redis 7.0.0 到 7.0.10版本、6.2.0 到 6.2.11版本、6.0.0 到 …...

Android保存网页的方法

首先要使用js交互就需要懂原理&#xff1a; 感谢大佬&#xff1a;js中document节点获取页面元素的六种方式 1.querySelector()方法 描述&#xff1a;本方法用于根据给定的选择器选中页面元素 如果有多个元素满足条件&#xff0c;则返回第一个满足条件的元素节点 语法&#xff…...

P2P 网络,PING程序。

没有废话,直接上版本号和代码,以及讲解。 crate版本号libp2p0.52.1tokio1.30.0依赖配置: [dependencies] tokio = { version="1.30.0", features=["full"] } libp2p = { version="0.52.1", features=["tokio","dns", &q…...

思源宋体TTF字体:7种字重的中文排版技术方案

思源宋体TTF字体&#xff1a;7种字重的中文排版技术方案 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 在中文数字内容创作中&#xff0c;字体选择直接影响用户体验和视觉传达效果。思…...

Qwen3-TTS完整使用教程:Web界面+Python API,满足不同需求

Qwen3-TTS完整使用教程&#xff1a;Web界面Python API&#xff0c;满足不同需求 1. 从文字到声音&#xff0c;一个模型搞定十国语言 想象一下&#xff0c;你有一段中文文案需要变成温柔的客服语音&#xff0c;一段英文产品介绍需要充满活力的男声&#xff0c;一段日文问候需要…...

Spring Boot Admin Server 2.3.1 保姆级搭建教程:从零到一,顺便搞定安全登录

Spring Boot Admin Server 2.3.1 零基础实战&#xff1a;从环境搭建到安全防护全解析 当你面对十几个微服务实例时&#xff0c;是否经常为查看日志、监控状态而频繁切换终端&#xff1f;Spring Boot Admin 就像给你的微服务集群装上了"全景天窗"&#xff0c;一站式解…...

Python 文件批量处理:重命名/备份/同步运维实战指南

老王在一家小公司管服务器。每天最烦的事&#xff0c;就是开发同事丢来一堆日志文件&#xff0c;文件名乱七八糟——有的叫log1.txt&#xff0c;有的叫1212.log&#xff0c;还有的直接叫新建文本文档(1).log。更糟的是&#xff0c;每周五要手动备份一遍配置文件&#xff0c;还得…...

笔记本EC与BIOS的‘暗号’:深入解读Q Event与GPIO SMI在电源、按键背后的协作

笔记本EC与BIOS的‘暗号’&#xff1a;深入解读Q Event与GPIO SMI在电源、按键背后的协作 当按下笔记本电源键时&#xff0c;这个看似简单的动作背后隐藏着一场精密的硬件交响乐。嵌入式控制器&#xff08;EC&#xff09;与BIOS通过Q Event和GPIO SMI这两种特殊通信机制&#…...

告别金鱼记忆!一文看透 LangGraph 是如何用 AgentState 和 Checkpoint 实现记忆隔离的

告别金鱼记忆&#xff01;一文看透 LangGraph 是如何用 AgentState 和 Checkpoint 实现记忆隔离的在开发 AI Agent 时&#xff0c;让大模型“记住刚才聊了什么”是一项最基础但也最容易让人头疼的需求。 如果你正在使用 LangChain 及其专门用于构建状态化 Agent 的核心库 LangG…...

别再死记硬背了!用华为eNSP模拟器5分钟搞懂MPLS TE隧道配置全流程

华为eNSP实战&#xff1a;5分钟可视化掌握MPLS TE隧道配置精髓 网络工程师的日常工作中&#xff0c;最令人头疼的莫过于面对一堆抽象协议概念却无从下手。MPLS TE&#xff08;多协议标签交换流量工程&#xff09;作为运营商级网络的核心技术&#xff0c;传统学习方式往往让初学…...

别再死记硬背了!用C#手写一个位运算模拟器,彻底搞懂与、或、非、异或

从零构建C#位运算模拟器&#xff1a;用二进制视角彻底理解与、或、非、异或 当你第一次在代码中看到x & y或~z这样的表达式时&#xff0c;是否曾好奇计算机究竟在底层做了什么&#xff1f;位运算作为编程语言中最接近硬件的操作之一&#xff0c;理解它的本质能让你写出更高…...

GPT-5.4 API 怎么低延迟调用?2026 年 5 种接入方案实测对比

上周 OpenAI 悄悄放出了 GPT-5.4&#xff0c;号称推理能力又上了一个台阶。我第一时间想接入到项目里试试&#xff0c;结果老问题又来了——官方 API 延迟高、Key 申请排队、计费规则又改了。折腾了两天&#xff0c;把市面上能找到的接入方案都试了一遍&#xff0c;今天把实测数…...

节点内存超限原因解析

你提供的截图显示的是一个 Kubernetes 节点&#xff08;Worker 节点&#xff09;的资源监控界面&#xff0c;其中&#xff1a;CPU 使用量&#xff1a;请求/限制/使用量 36.67% / 52.54% / 1.62%内存使用量&#xff1a;请求/限制/使用量 41.87% / 60.75% / 69.95%️ 注意&…...