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

【数据库概论】10.1 事务及其作用

事务是一系列的数据库操作,是数据库应用程序的基本逻辑单元

10.1 事务的基本概念

1.事务
事务是用户定义的一个数据库操作序列,是一个具有原子性的操作,不可再分,一个事务内的操作要么全做、要么都不做。一般来说,一个程序中包含多个事务。

事务通常以BEGIN TRANSACTION 开始,以COMMIT或者ROLLBACK结束。COMMIT表示提交,提交事务的所有操作,将事务中所有对数据库的更新写回到磁盘的物理数据库中。ROLLBACK表示回滚,表示在事务执行过程中出现了故障,系统将事务对数据库已完成的操作全部撤销,回滚到事务开始时的状态。

2.事务的ACID特性
Atomicity:原子性
事务是数据库逻辑工作的原子单位,事务中的操作要么全做,要么不做

Consistency:一致性
事务执行的结果必须是使得数据库从一个一致性状态变到另一个一致性状态,也就是说一个事务执行前和执行后都需要处于一致性状态。事务的执行必须是一气呵成的。可见一致性和原子性密切相关。比如A向B转账1万块,那么作为转账事务,要么A减少1万,B增加1万;要么转账失败,两边都不变。不存在A不变但B多1万,或者A少1万B不变的情况

Isolation:隔离性
一个事务的执行不能被其他事务所干扰,就是一个事务的内部操作及其使用的数据对其他并发事务时隔离的。

Durability:持续性
一个事务一旦提交,对数据库中数据的改变应该是永久性的

事务ACID特性可能遭到破坏的因素有:

  • 多个事务并行运行,不同事务的操作交叉执行
  • 事务在运行过程中被强制停止
http://www.lryc.cn/news/36939.html

相关文章:

  • 通讯录(C++实现)
  • 轻松掌握C++的模板与类模板,将Tamplate广泛运用于我们的编程生活
  • pandas 数据预处理+数据概览 处理技巧整理(持续更新版)
  • mmdetectionV2.x版本 训练自己的VOC数据集
  • Shell - crontab 定时 git 拉取并执行 maven 打包
  • 408考研计算机之计算机组成与设计——知识点及其做题经验篇目3:指令的寻址方式
  • 前端包管理工具:npm,yarn、cnpm、npx、pnpm
  • 推荐系统 FM因式分解
  • Maven基础入门
  • 传输层协议 TCP UDP
  • 一点就分享系列(实践篇6——上篇)【迟到补发】Yolo-High_level系列算法开源项目融入V8 旨在研究和兼容使用【持续更新】
  • buu RSA 1 (Crypto 第一页)
  • Python 二分查找:bisect库的使用
  • 性能优化之HBase性能调优
  • 图像金字塔,原理、实现及应用
  • 08-Oracle游标管理(定义,打开、获取数据及关闭游标)
  • Python判断字符串是否包含特定子串的7种方法
  • aop实现接口访问频率限制
  • Hive---窗口函数
  • JavaSe第7次笔记
  • 什么是 Service 以及描述下它的生命周期。Service 有哪些启动方法,有 什么区别,怎样停用 Service?
  • Redis部署
  • AT32F437制作Bootloader然后实现Http OTA升级
  • Springboot项目启动初始化数据缓存
  • 深度学习必备知识——模型数据集Yolo与Voc格式文件相互转化
  • 数据、数据资源及数据资产管理的区别
  • 标度不变性(scale invariance)与无标度(scale-free)概念辨析
  • WMS仓库管理系统解决方案,实现仓库管理一体化
  • css常见定位、居中方案_css定位居中
  • 【微信小程序】-- 自定义组件 -- 创建与引用 样式(三十二)