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

乐观锁和悲观锁 面试题

Mysql的乐观锁和悲观锁 

实现方式加锁时机常见的调用方式优势不足适用场景
乐观锁开发自定义更新数据的时候sql语句中进行version的判断高并发容易出现不一致的问题高并发读,少写
悲观锁Mysql内置查询数据的开始select * for update保证一致性低并发互联网高并发场景极少使用了,多见于某些产品内置的数据库系统

乐观锁

  顾名思义,总是一副乐天派的样子。每次读取数据时都很乐观,认为绝不会产生并发问题(不会有其他线程对数据进行修改)。因此,一般也不会上锁。只有在更新数据时才会去判断其他线程在此期间有没有对数据进行修改。

  若未修改,则操作成功;若数据已经发生了变化则表明期间有被修改,则事务回滚并错误提示给用户端。

  简单理解:别想太多,你尽管用,出问题了算我怂,大不了操作失败后事务回滚、提示用户!!!

  常见的实现机制为“版本号控制”,简化版的实现思路如下:

    • 读取记录时,获取当前version
    • 更新时,带上这个version
    • 执行更新时, set version = newVersion where version = oldVersion
    • 如果version不对,则更新失败,事务回滚
update table set name = 'Aron', version = version + 1 where id = #{id} and version = #{version};  

悲观锁

  顾名思义,总是假设最坏的情况。每次读取数据时都认为其他线程会同时修改数据,所以每次读取都会加(悲观)锁。

  一旦加锁,不同线程同时执行时只能有一个线程执行成功,其他的线程在入口处等待,直到锁被释放。

  常见的应用有:

    • MySQL的读锁、写锁、行锁等
    • Javasynchronized关键字

    

分类: MySQL

 乐观锁, MySQL, 悲观锁

 


http://www.kler.cn/a/2291.html

相关文章:

  • Android获取sim卡频段信息
  • 深入理解 HTTP HEAD 请求:节省带宽、提高效率的秘密武器
  • RadiAnt DICOM - 基本主题 :从 PACS 服务器打开研究
  • java 基于冷热数据分离的思想设计LRU链表
  • electron打包linux环境
  • 常用的JVM启动参数有哪些?
  • vue使用split()将字符串分割数组join()将数组转字符串reverse()将数组反转
  • Linux 总结9个最危险的命令,一定要牢记在心!
  • 通过DNS数据包解释DNS协议各个字段含义
  • Java中 ==和equals的区别是什么?
  • 流量分析-Wireshark -操作手册(不能说最全,只能说更全)
  • Golang每日一练(leetDay0012)
  • 让项目干系人满意的3大要点
  • list底层的简单实现(万字长文详解!)
  • 今天,我终于学懂了C++中的引用
  • 全网最全面,python自动化测试持续邮件集成,一步步详解......
  • 【Python_requests学习笔记(六)】基于requests模块构建免费代理IP池
  • 程序员的代码行数越少越好?
  • 【STL四】序列容器——vector容器
  • 【2023.3.18 美团校招】
  • 微前端(无界)
  • 今天面试了一个2年Java经验的
  • Selenium基础篇之不打开浏览器运行
  • 136. 只出现一次的数字
  • 第十四届蓝桥杯三月真题刷题训练——第 19 天
  • 推荐 5 个好玩的 ChatGPT 开源应用