技术基础理论(面试)

面试技巧:回答要条理清晰,用术语但要解释清楚,避免过于深入实现细节。

1、数据库的隔离级别

概念

  • 隔离级别是用于控制多个事务同时执行时,它们之间的相互影响程度。
  • 核心 - 是为了平衡数据一致 性和并发性能

如果不隔离,主要会出现三种"读异常":

  • 脏读:同时刻的两个事务中,事务A读取了事务B尚未提交的修改数据(磁盘值为200,内存中值为100)。如果B之后回滚了,A读到的就是无效的"脏"数据:100。
  • 不可重复读:在同一个事务A内,两次读取同一条数据,得到的结果不一样。这是因为在这两次读取之间,事务B修改并提交了这条数据。
  • 幻读:在同一个事务A内,两次执行同一个查询条件,得到的记录条数不一样。这是因为两次查询之间,事务B新增或删除了符合条件的数据行。
复制代码
注意:脏读特指读未提交的数据。
  在"可重复读"下,A第二次读到的依然是100元不算脏读,
  所以事务A读到的100元,是一个已提交的历史数据(或称快照数据),而不是一个尚未确定的"脏"数据。不符合脏读的定义。

如何选择隔离级别?这需要在"数据准确度"和"系统响应速度"之间做权衡:

  • 读未提交:几乎不用。除非你对数据准确性完全不在意,只追求极致速度。
  • 读已提交:很多在线交易系统的默认选择。保证不会读到脏数据,性能也不错,但需容忍同一事务内查询结果的变化。
  • 可重复读:适合需要一致数据快照进行报表统计的场景。MySQL的默认级别表现很好,多数情况下足够安全。
  • 可串行化:只在严格禁止任何并发数据冲突的场景使用(如余额绝对精确的金融核心系统),但会严重影响并发性能。
相关推荐
千寻girling3 小时前
一份不可多得的《微服务》教程
后端·面试·github
swipe4 小时前
从 0 到 1 理解 React 虚拟列表:定高、不定高与 Canvas 版本完整拆解
前端·javascript·面试
Ruihong6 小时前
🎉 VuReact 1.9.0 发布,支持 Vue 3.4 defineModel 编译到 React
vue.js·react.js·面试
假如让我当三天老蒯7 小时前
React基础、进阶(学习用)
前端·react.js·面试
swipe20 小时前
从 0 到 1 实现大文件上传:分片、秒传、断点续传、暂停、重试与服务端合并
前端·javascript·面试
阳火锅1 天前
😭测试小姐姐终于不骂我了!这个提BUG神器太香了...
前端·javascript·面试
林希_Rachel_傻希希1 天前
js里面的proxy理解。以及vue3响应式数据设计底层
前端·javascript·面试
用户1563068103511 天前
Day01 | 什么是Agent?
面试
写代码的皮筏艇1 天前
React中的forwardRef
前端·react.js·面试
蝎子莱莱爱打怪2 天前
XZLL-IM干货系列 03|消息 ID 设计:一个 UUID 搞不定的事,我用两个 ID 解决了
后端·面试·开源