Classification of lock operation types
  • Read lock: Shared lock. Multiple read operations can be performed on the same data without affecting each other.

  • Write lock: Exclusive lock that blocks other write locks and read locks until the write operation is complete.

Operation granularity classification of locks
  • Table locks: biased to read, MyiSAM
  • Row locking: Bias to write, InnoDB

MyiSAM

  • Before performing a SELECT operation, MyiSAM locks the tables involved. At this point, other sessions can normally operate on the unlocked table. However, a table with a read lock can only be queried (shared lock). Modifying the table will be blocked and will take effect only after the table is unlocked.

  • Session1 Session2
    Lock TABLE_A No operation
    TABLE_A can be queried but cannot be modified TABLE_A can be queried but cannot be modified
    An error occurred when querying TABLE_B. Procedure Query and modify TABLE_B
    Error when modifying TABLE_A Modify TABLE_A to block
    Unlock tables; unlock TABLE_A modified
  • Before a write operation, MyiSAM locks the tables involved. At this point, other sessions can normally operate on the unlocked table. However, any read or write to a table with a write lock will be blocked until the write lock is released.

    • Session1 Session2
      Write lock TABLE_A No operation
      You can modify TABLE_A but cannot query TABLE_A TABLE_A cannot be queried or modified
      TABLE_B cannot be operated on You can do something to TABLE_B
      An error occurred when querying TABLE_A Query or modify TABLE_A is blocked
      Unlock tables; unlock TABLE_A is queried or modified
  • MyiSAM’s read-write lock scheduling is write-first, which is why MyiSAM is not suitable as a write-oriented engine. Because no other thread can do anything after a lock is written, a large number of writes can make it difficult for a query to get a lock, causing permanent blocking.





IMPORTANT

Colloquially:

  • Read lock is: I want to backup, don’t touch (modify) things later;

  • Write lock is: I want to modify, the back don’t hurry, line up (no matter you are to read or to change, have to wait for me to change).





InnoDB

InnoDB’s locking mechanism is row locking and row locking supports transactions.





ACID properties of transactions:
  • A Atomic: A transaction is the smallest unit that cannot be divided further, and either all or none of the transactions will be executed.
  • C Consistency: The data is consistent before and after the transaction, that is, the integrity of the database will not be compromised.
  • I Isolation: it means that the transaction will not be disturbed by other transactions or database operations in the execution process, and the intermediate state in the execution process of several transactions will not be visible to the outside world.
  • D Durability: Their impact on the database after transactions complete is persistent and does not roll back.





Problems with concurrent transactions:
  • Update loss: Multiple transactions update the same row at the same time and are unaware of the existence of other transactions, resulting in the last update being invalidated (lost).

  • Dirty read: When a transaction attempts to read intermediate data during data update (data that has been modified but has not been committed), the data does not meet consistency requirements.

  • Non-repeatable read: During a transaction, a certain data is read twice or more, and another transaction modifies the data between the two read operations. As a result, the two read operations cannot be repeated (otherwise, the data will be different).

  • Phantom read: a transaction in which a few rows of data are read before another transaction adds or deletes the data. After that, the transaction reads the data and finds that the data is created or disappears out of thin air.

Summary: Update loss is a problem that occurs when multiple transactions modify data almost simultaneously; Dirty reads are problems that occur when one transaction is modifying data and another transaction is reading (SELECT) data. Unrepeatable read is a problem where one transaction is querying data and another transaction is updating the data in the middle; The illusion is that one transaction is querying data and another is inserting or deleting data.





Transaction isolation level:
  • Read Uncommitted: Indicates the lowest level. This level can only avoid data that is not Read during physical data modification. Intermediate states of logical data modification still exist, which damages data consistency.
  • Read Committed: Statement level, guaranteed atomicity, can only Read Committed data, but there is no lock during data modification, why only Read Committed data? , this is the use of “snapshot read” optimization, so that we modify data at the same time, the query will not be blocked, can complete high concurrency query, greatly improve efficiency; However, because there is no lock in the process of modification, there will be two times in the process of querying data, data is modified or added by other transactions, resulting in unrepeatable read and illusory read.
  • Repeated Read: transaction level (default isolation level of MySQL) Common query also adopts the “snapshot read” mode to avoid dirty read. On this basis, the data row involved cannot be modified when a transaction is started, thus avoiding the problem of “data read in the same transaction is inconsistent”. But there is no avoiding phantom (phantom is solved in InnoDB “gap lock plus row lock”).
  • Serializable: The highest level, transaction level, executes transactions sequentially, that is, executes transactions one by one. At this level, all concurrent transaction problems are avoided, but efficiency is greatly reduced by switching from parallel to serial queued operations.





Committed reads and repeatable reads are the two transaction isolation levels most commonly used in real development. The two are the main solution to the Concurrency transaction problem via the Multi Version Concurrency Control (MVCC).

  • Read CommitedTo create a snapshot of the transaction before each SQL statement is executed, and avoid dirty reads when other concurrent transactions attempt to read the data.
  • Repeated ReadTo avoid dirty reads and unrepeatable reads, a snapshot is generated before the first query of a transaction and is read during the next transaction.





To summarize the relationship between lock and isolation levels and concurrency issues:

At the default isolation level, when we modify or query certain rows of data, only these rows are locked, thus avoiding the occurrence of unrepeatable reads. And we even for the whole list all rows in the operation, it is locked every row of this table, not to Lock up this form, can’t stop table insert new lines, and still can appear the phantom read Lock (clearance + Next row locks – Key Lock solves this problem), and the highest isolation level is through the transaction serialization, It is not possible for other transactions to insert data while executing query transactions, thus avoiding phantom reads.





Gap Lock

When we query a statement for a range, InnoDB locks the range regardless of whether it has data or not, and inserts or deletes data into the “gap” (non-existent rows) of the range block.





Next-Key Lock

Next Key Lock = Record Lock + Gap Lock InnoDB uses next-key Lock to solve the illusion problem in a default isolation level (Repeated Read).

That is, in the scope SELECT, we first add Record Lock to the existing Records, and then add Gap Lock to the interval, so as to solve the illusion problem.





Index failures turn a row lock into a table lock

Cause: full table scan caused by index failure, causing secondary row lock -> table lock.


How to lock a row

The select… For update statement






Optimization Suggestions

  • As much as possible, all data retrieval is done through the index, to avoid non-indexed row locks to upgrade to table locks.
  • Design indexes to minimize lock access.
  • Reduce retrieval conditions as much as possible to avoid the harm of gap locking.
  • Try to control the transaction size to reduce the amount of resources locked and the length of time.
  • The lowest possible level of transaction isolation.





The biggest difference between InnoDB and MyiSAM is that InnoDB supports transactions, row locks and foreign keys, while MyiSAM does not.Specific articles