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

数据库之事务

数据库之事务

事务的特点:

ACID

原子性

一致性:数据库的完整性约束,不能被破坏

隔离性

持久性:数据一旦提交,事务的效果将会被永久的保留在数据库中。而且不会被回滚

主从复制

高可用

备份

权限控制

脏读:另外一个事务能够看到另一个事务未提交的修改结果

事务隔离级别的作用范围:

1、全局级:对所有的会话有效

2、会话级:只对当前的会话有效

show global variables like %isolation;:查询全局事务的隔离级别

select @@global.txisolation;:查询全局事务的隔离级别

show session variables like %isolation;:查询会话事务的隔离级别

select @@session.txisolation;:查询会话事务的隔离级别

设置全局事务的隔离级别:

set global transation isolation level read uncommitted;

临时修改全局事务的隔离级别,重启服务即失效:

set @@global.tx_isolation=read uncommitted;

设置会话的隔离级别:

set session transation isolation level read uncommitted;

设置临时会话的隔离级别:

set @@session.tx_isolation=read uncommitted;

不可重复读:一个事务内,多次读同一数据

前一个事务还没有结束,另一个事务也访问该数据

在一个事务之内,两次查询到结果不一致,读不到相同的数据内容

幻读:一个事务对一个表中的数据进行了修改,可能会涉及到表中的全部数据。

另一个事务也修改了表中的数据。

例如插入了一行新的数据,前一个事务会发现表中还有数据没有修改,类似于幻觉

丢失更新:两个事务同时修改一条记录,A先记录,B也修改了记录,B一旦提交会覆盖A的结果

面试题:

以上这些情况如何避免:

1、权限控制

2、根据情况来使用隔离级别

生产环境----最好是提交读

测试环境----无所谓

3、生产环境只能允许一个人对一个事务进行操作。其他人不允许操作

总结:在事务管理中,原子性是基础,隔离性是手段,一致性是目的 持久性是最终的结果

事务的控制语句:

BEGIN:显示的开启事务

START transaction:显示的开启事务

commit:提交事务

commit work:提交事务

rollback:回滚(撤销正在进行的所有未提交的修改)

rollback work:回滚(撤销正在进行的所有未提交的修改)

savepoint s1;:创建回滚点,一个事务可以有多个回滚点

rollback to s1;:回滚到还原点

注意:

1、多点还原,s1和s2

如果说还原到s1

mysql提交事务是默认提交

可以用set来设置mysql的提交方式:

show variables like autocommit;

set autocommit=0;

默写:

1、AICD:分别是什么

A:原子性

C:一致性

I:隔离性

D:持久性

2、mysql支持的隔离级别分别是什么?

未提交读

可重复读

提交读

串行读

3、脏读,幻读,不可重复读和丢失更新怎么预防?

权限控制

设置合理的隔离级别

生产中主要还是串行读

http://www.lryc.cn/news/221311.html

相关文章:

  • NOIP2023模拟12联测33 B. 游戏
  • 代码随想录打卡第六十三天|84.柱状图中最大的矩形
  • python tempfile 模块使用
  • 【软件测试】接口测试实战详解
  • 轻量封装WebGPU渲染系统示例<20>- 美化一下元胞自动机之生命游戏(源码)
  • Nodejs的安装以及配置(node-v12.16.1-x64.msi)
  • 03【保姆级】-GO语言变量和数据类型和相互转换
  • mermaid学习第一天/更改主题颜色和边框颜色/《需求解释流程图》
  • SAP MASS增加PR字段-删除标识
  • 【手把手教你】训练YOLOv8分割模型
  • 物料主数据增强屏幕绘制器DUMP
  • vue 实现在线预览Excel-LuckyExcel/LuckySheet实现方案
  • AIGPT重大升级,界面重新设计,功能更加饱满,用户体验升级
  • Web逆向-mtgsig1.2简单分析
  • 【蓝桥杯省赛真题41】Scratch电脑开关机 蓝桥杯少儿编程scratch图形化编程 蓝桥杯省赛真题讲解
  • 第10章 Java常用类
  • Android 11 getPackageManager().getPackageInfo 返回null
  • 4、数据结构
  • qt5.15.2+vs2019源码调试开发环境搭建
  • 【数据结构】单链表之--无头单向非循环链表
  • 网络中使用最多的图片格式有哪些
  • 个人常用Linux命令
  • 数据结构——常见简答题汇总
  • josef约瑟低电压继电器 DY-110 10-109V 辅助电源·DC110V 嵌入式面板安装
  • Visual Studio Code将中文写入变量时,中文老是乱码问题
  • 各省市30米分辨率DEM数据,推荐下载!
  • 操作系统引论(一)
  • 2023-11-7 OpenAI 45 分钟发布会:整理发布了哪些内容更新
  • 索引和事务
  • 全场景数实融合聚焦北京——2023(第六届)行业信息技术应用创新大会隆重召开