`

innodb 加锁

 
阅读更多

转载http://my.oschina.net/xinxingegeya/blog/296591

显式加锁

  • select ... lock in share mode:加 S 锁 

  • select ... for update:加 X 锁 

 

MySQL快照读和当前读

在一个支持MVCC并发控制的系统中,哪些读操作是快照读?哪些操作又是当前读呢?以MySQL InnoDB为例:

快照读:简单的select操作,属于快照读,不加锁。(当然,也有例外,下面会分析)

select * from table where ?;

当前读:特殊的读操作,插入/更新/删除操作,属于当前读,需要加锁

select * from table where ? lock in share mode;

select * from table where ? for update;

insert into table values (…);

update table set ? where ?;

delete from table where ?;

 

所有以上的语句,都属于当前读,读取记录的最新版本。并且,读取之后,还需要保证其他并发事务不能修改当前记录,对读取记录加锁。其中,除了第一条语句,对读取记录加S锁 (共享锁)外,其他的操作,都加的是X锁 (排它锁

分享到:
评论

相关推荐

    mysql加锁分析_v1

    通过对MySQL/InnoDB加锁机制的深入分析,我们不仅可以更好地理解SQL语句的行为,还能有效避免死锁的发生,提升系统的并发处理能力和整体性能。希望本文提供的方法论能够帮助开发者和技术人员在实际工作中更加...

    4.5 mysql 加锁分析.pdf

    通过对MySQL/InnoDB加锁机制的深入探讨,我们不仅了解了其背后的原理和技术细节,还学会了如何分析SQL语句的加锁行为及其可能带来的风险。此外,掌握如何利用这些知识来解决实际问题,如诊断死锁原因,对于提高...

    mysql加锁分析

    通过对MySQL/InnoDB加锁机制的深入分析,我们可以看到,不同的SQL语句组合、隔离级别以及索引类型都会影响加锁行为。掌握这些基础知识有助于我们在设计应用程序时做出更加合理的选择,避免潜在的并发问题,提高...

    MySQL 加锁处理分析1

    通过对MySQL/InnoDB加锁机制的深入分析,我们可以更好地理解和预防潜在的并发问题,优化查询性能,并确保数据库的一致性和稳定性。了解这些知识对于数据库管理员和开发人员来说是至关重要的,可以帮助他们在设计和...

    MySQL复制-性能与扩展性的基石3:常见问题及解决方案.docx

    **问题描述**:InnoDB加锁机制可能会导致复制延迟或死锁等问题。 **解决方案**: - 优化SQL语句,减少长时间运行的事务。 - 调整InnoDB相关的配置参数,如`innodb_lock_wait_timeout`等,以适应特定的工作负载需求...

    MySQL加锁处理分析@何登成1

    MySQL/InnoDB 的加锁分析一直是一个比较困难的话题。了解 MySQL 加锁机制对数据库性能和可靠性的影响非常重要。本文将对 MySQL/InnoDB 的加锁机制进行深入分析和讨论。 二、MVCC:Snapshot Read vs Current Read ...

    MySQL中InnoDB存储引擎的加锁分析

    文档中深入浅出的,详细描述了一条 SQL 是如何实现加锁的,包含了各种索引组合和各种隔离级别下的分析;同时也详细地剖析了死锁的原理和解决办法。 适用人群: 1、想加深对 MySQL了解,想要深入学习数据库底层的人群...

    阿里大牛何sir 深入MySQL加锁处理分析

    本文将重点讨论InnoDB存储引擎的加锁机制。 MVCC(Multi-Version Concurrency Control,多版本并发控制)是InnoDB存储引擎实现的一种并发控制协议。在MVCC中,读操作可以分为两种类型:快照读(Snapshot Read)与...

    InnoDB 中文参考手册

    InnoDB 提供了行锁(locking on row level),提供与 Oracle 类型一致的不加锁读取(non-locking read in SELECTs)。这些特性均提高了多用户并发操作的性能表现。在InnoDB表中不需要扩大锁定(lock escalation),因为 ...

    何登成 - 管中窥豹——MySQL(InnoDB)死锁分析之道

    在实际中,解决MySQL(InnoDB)的死锁问题需要深入了解死锁产生的原因、锁的类型以及加锁策略,进而对业务逻辑进行优化或调整数据库配置和代码逻辑以减少死锁的可能性。 ### 个人简介 何登成作为阿里巴巴DBA团队的...

    MySQL DELETE 删除语句加锁分析1

    在MySQL中,DELETE语句的加锁行为是数据库事务处理的重要组成部分,尤其是在并发环境中,正确理解其加锁机制对于避免死锁和提高系统性能至关重要。本篇文章主要探讨了在不同隔离级别下,针对不同索引类型的DELETE...

    InnoDB事务、锁、多版本分析

    事务的主要功能包括快照读和当前读,前者通过创建ReadView来实现不同隔离级别的查询,后者则会在读取或修改数据时加锁。 InnoDB支持XA事务,这是分布式事务的一种标准,目的是保证跨多个数据库节点的操作一致性。在...

    何登成的技术博客 » MySQL 加锁处理分析1

    MySQL的加锁处理是数据库并发控制的重要机制,尤其在InnoDB存储引擎中,它采用多版本并发控制(MVCC)来提升系统的并发性能。MVCC允许读操作在不加锁的情况下进行,从而减少了读写冲突,但同时也引入了快照读和当前...

    InnoDB中文参考手册

    InnoDB 提供了行锁(locking on row level),提供与 Oracle 类型一致的不加锁读取(non-locking read in SELECTs)。这些特性均提高了多用户并发操作的性能表现。在InnoDB表中不需要扩大锁定(lock escalation),因为 ...

    InnoDB怎么应对高并发

    特别是MVCC机制,通过快照读(不加锁的SELECT)避免了读写冲突,极大地提高了读写并发性能。此外,通过redo日志优化随机写入为顺序写入,改善了磁盘I/O性能,进一步提升了数据库的吞吐量。这些技术的巧妙结合,使得...

    Innodb存储引擎浅析—事务系统

    ### Innodb存储引擎浅析—事务系统 #### 学述 在MySQL的众多存储引擎中,InnoDB无疑是最为重要且被广泛使用的之一。本文旨在深入解析InnoDB存储引擎中的事务处理机制及其背后的设计原理。 #### 存储引擎介绍 在...

    innodb行锁实现的一些例子1

    InnoDB 行锁是通过给索引上的索引项加锁来实现的,这与 Oracle 不同,后者是通过在数据块中对相应数据行加锁来实现的。这种行锁实现特点意味着:只有通过索引条件检索数据,InnoDB 才使用行级锁,否则,InnoDB 将...

    MySQL核心Innodb存储引擎浅析—事务系统

    ### MySQL核心Innodb存储引擎浅析—事务系统 #### 存储引擎介绍 在MySQL中,存储引擎是处理表的存储方式的核心组件之一。不同的存储引擎提供了不同的特性,如事务支持、锁定粒度等。其中,MyISAM和InnoDB是最常用...

Global site tag (gtag.js) - Google Analytics