Home > Database > Mysql Tutorial > How Can I Perform Non-Locking SELECT Queries in MySQL?

How Can I Perform Non-Locking SELECT Queries in MySQL?

Mary-Kate Olsen
Release: 2024-12-15 16:56:15
Original
265 people have browsed it

How Can I Perform Non-Locking SELECT Queries in MySQL?

Non-Locking SELECT Queries in MySQL

In MySQL, frequent locking during SELECT operations can arise when tables are concurrently modified. To mitigate this issue, consider using techniques that allow for non-locking reads.

Using READ UNCOMMITTED

One approach is to set the transaction isolation level to READ UNCOMMITTED, which allows reads without acquiring locks. However, this option may not be suitable for slaves as it compromises data integrity.

The SQL Equivalent of WITH (NOLOCK)

For equivalence to the WITH (NOLOCK) clause in Microsoft SQL Server, MySQL offers a multi-step process:

  1. Start the transaction with READ UNCOMMITTED isolation:

    SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
    Copy after login
  2. Perform the SELECT query:

    SELECT * FROM TABLE_NAME;
    Copy after login
  3. Reset the transaction isolation level back to REPEATABLE READ:

    SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ;
    Copy after login

Improved Non-Locking Query Execution

Michael Mior proposed an improved version of the non-locking query execution:

  1. Set the transaction isolation level to READ UNCOMMITTED:

    SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED ;
    Copy after login
  2. Perform the SELECT query:

    SELECT * FROM TABLE_NAME ;
    Copy after login
  3. Commit the transaction:

    COMMIT ;
    Copy after login

The above is the detailed content of How Can I Perform Non-Locking SELECT Queries in MySQL?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template