Java面试题:并发事务问题和事务隔离级别

并发事务问题

脏读

一个事务读到了另一个事务还没有提交的数据

幻读

按条件查询数据时发现没有数据,但插入时数据存在,就像出现了幻觉

不可重复读

同一个事务先后读取同一条记录,但两次读取的数据不同,称之为不可重复读

解决事务问题的方法

对事务进行隔离

Read Uncommitted 未提交读(不常用)

存在问题:脏读,幻读,不可重复读

Read committed 读已提交

存在问题:幻读,不可重复读 解决:脏读

Repeated Read 可重复读(mysql默认)

存在问题:幻读 解决:脏读,不可重复读

Serializable 串行化(不常用)

所有事务必须串行执行,在上一个事务完成后才能执行下一个事务

解决:脏读 幻读 不可重复读

相关推荐
-Xie-30 分钟前
Redis(八)——多线程与单线程
java·数据库·redis
Kuo-Teng34 分钟前
LeetCode 279: Perfect Squares
java·数据结构·算法·leetcode·职场和发展
IMPYLH40 分钟前
Lua 的 collectgarbage 函数
开发语言·笔记·junit·单元测试·lua
Filotimo_1 小时前
SpringBoot3整合Druid数据源
java·spring boot
百锦再1 小时前
第18章 高级特征
android·java·开发语言·后端·python·rust·django
Tony Bai1 小时前
Go 在 Web3 的统治力:2025 年架构与生态综述
开发语言·后端·架构·golang·web3
乄bluefox1 小时前
Reactor 中的 doOnError 与 doOnCancel
java·reactor·rea
CoderYanger1 小时前
B.双指针——3194. 最小元素和最大元素的最小平均值
java·开发语言·数据结构·算法·leetcode·职场和发展·1024程序员节
Charles_go1 小时前
C#中级、double和decimal有什么区别
开发语言·c#