Overview of MySQL locks
Compared with other databases, MySQL’s lock mechanism is relatively simple, and its most significant The characteristic is that different storage engines support different lock mechanisms. For example, the MyISAM and MEMORY storage engines use table-level locking. The BDB storage engine uses page-level locking, but it also supports table-level locks. The InnoDB storage engine supports both row-level locking and table-level locking, but row-level locking is used by default.
Table-level lock: Table-level lock is the lock with the largest granularity in MySQL, which means locking the entire table of the current operation. It has low overhead and fast locking; no deadlock will occur; the locking granularity is large, the probability of lock conflict is the highest, and the concurrency is the lowest.
Free learning video tutorial sharing: mysql video tutorial
Row-level lock: Row-level lock is the most granular lock in MySQL, which means it is only for the current The row being operated is locked. The overhead is high and locking is slow; deadlocks may occur; the locking granularity is the smallest, the probability of lock conflicts is the lowest, and the concurrency is the highest.
Page-level lock: Page-level lock is a lock in MySQL whose locking granularity is between row-level locks and table-level locks. Table-level locks are fast, but have many conflicts. There are fewer row-level conflicts, but it is slower. So a compromised page level was adopted, locking a group of adjacent records at a time. BDB supports page-level locks. The overhead and locking time are between table locks and row locks; deadlocks will occur; the locking granularity is between table locks and row locks, and the concurrency is average.
It can be seen from the above characteristics that it is difficult to say which lock is better in general. We can only say which lock is more suitable based on the characteristics of specific applications! ! From a lock perspective only: Table-level locks are more suitable for applications that are mainly query-based and only have a small amount of data updated based on index conditions, such as Web applications. Row-level locks are more suitable for applications where a large number of different data are concurrently updated according to index conditions and concurrent queries are performed, such as some online transaction processing (OLTP) systems.
Examples
1. When purchasing a product, when there is only one product in stock, and two people purchase it at the same time, who buys it? The problem.
2. Transactions will be used to first retrieve the item data from the inventory table, then insert the order, and after payment, insert the payment table information.
3. Update the quantity of goods. In this process, locks can be used to protect limited resources and solve the contradiction between isolation and concurrency.
Classification of locks
By operation:
Read lock (shared lock): multiple reads for the same data Operations can be performed simultaneously without affecting each other.
Write lock (exclusive lock): Before the current write operation is completed, other write locks and read locks will be blocked.
According to granularity:
Table lock, row lock, page lock
Recommended related article tutorials: mysql tutorial
The above is the detailed content of How to understand the mysql lock mechanism. For more information, please follow other related articles on the PHP Chinese website!

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

在mysql中,是否需要commit取决于存储引擎:1、若是不支持事务的存储引擎,如myisam,则不需要使用commit;2、若是支持事务的存储引擎,如innodb,则需要知道事务是否自动提交,因此需要使用commit。

在mysql中,可利用“ALTER TABLE 表名 DROP INDEX unique key名”语句来删除unique key;ALTER TABLE语句用于对数据进行添加、删除或修改操作,DROP INDEX语句用于表示删除约束操作。

如何正确理解PHP中的值传递方式PHP是一种广泛应用于Web开发的脚本语言,而在PHP中的参数传递方式主要有值传递和引用传递两种。而理解PHP中的值传递方式对于编写高效的代码至关重要。本文将详细讨论PHP中的值传递方式,并通过具体的代码示例来帮助读者更好地理解。值传递方式的基本概念值传递是指将变量的值复制一份传递给函数或方法,在函数内部对该值的操作不会影响到

深入理解Linux管道的使用方法在Linux操作系统中,管道是一种非常有用的功能,能够将一个命令的输出作为另一个命令的输入,从而方便地实现各种复杂的数据处理和操作。深入理解Linux管道的使用方法对于系统管理员和开发人员来说非常重要。本文将介绍管道的基本概念,并通过具体的代码示例来展示如何使用Linux管道进行数据处理和操作。1.管道的基本概念在Linux

深入理解Go语言文档中的strings.Split函数,需要具体代码示例在Go语言中,字符串操作是非常常见的需求。其中,strings包是Go语言提供的一个标准包,提供了丰富的字符串处理函数。其中,strings.Split函数是其中一个常用的函数,它的作用是根据指定的分隔符将一个字符串拆分成一个字符串切片。在正式深入探讨strings.Split函数之前,


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SublimeText3 Linux new version
SublimeText3 Linux latest version

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function
