What are the database transaction isolation levels?
Database transaction isolation level: 1. Read Uncommitted (read uncommitted); 2. Read Committed (read committed); 3. Repeatable Read (repeatable read); 4. Serializable (serializable) ).
The operating environment of this tutorial: windows7 system, mysql8 version, Dell G3 computer.
In database operations, a transaction (Transaction) is an indivisible unit of work composed of one or more SQL statements that operate the database. These operations are either completed or canceled.
Database transaction isolation level
In practical applications, the data in the database is accessed by multiple users. When users operate the same data at the same time, some transaction concurrency issues may occur, as detailed below.
1) Dirty reading
means that one transaction reads uncommitted data from another transaction.
2) Non-repeatable read
means that a transaction reads the same row of data twice, but the results are different.
3) Virtual read/phantom read
means that a transaction executes two queries, but the result of the second query contains data that did not appear in the first query.
4) Lost update
means that two transactions update a row of data at the same time, and the transaction submitted (or revoked) later overwrites the data submitted by the previous transaction.
Lost updates can be divided into two categories, namely the first type of lost updates and the second type of lost updates.
The first type of lost update refers to when two transactions operate the same data at the same time. When the first transaction is canceled, the updated data of the second transaction that has been submitted is overwritten. , the second transaction caused data loss.
The second type of lost update refers to when two transactions operate on the same data at the same time. After the first transaction successfully submits the modification results, the modifications that have been submitted by the second transaction are The result was overwriting, resulting in data loss for the second transaction.
In order to avoid the above transaction concurrency problems, four transaction isolation levels are defined in the standard SQL specification. Different isolation levels handle transactions differently. The isolation levels of these four transactions are as follows.
1) Read Uncommitted (read uncommitted)
During the execution of a transaction, it can access both newly inserted data that has not been committed by other transactions and Uncommitted modified data. If a transaction has started writing data, another transaction is not allowed to write data at the same time, but other transactions are allowed to read this row of data. This isolation level prevents lost updates.
2) Read Committed
During the execution of a transaction, it can access both the newly inserted data successfully submitted by other transactions and the Successfully modified data. The transaction that reads the data allows other transactions to continue to access the row of data, but the uncommitted write transaction will prevent other transactions from accessing the row. This isolation level effectively prevents dirty reads.
3) Repeatable Read
During the execution of a transaction, it can access newly inserted data successfully submitted by other transactions, but it cannot Access successfully modified data. Transactions that read data will disable write transactions (but allow read transactions), and write transactions will disable any other transactions. This isolation level effectively prevents non-repeatable reads and dirty reads.
4) Serializable (serializable)
Provides strict transaction isolation. It requires transactions to be executed serially, and transactions can only be executed one after another and cannot be executed concurrently. This isolation level effectively prevents dirty reads, non-repeatable reads, and phantom reads. However, this level may lead to a large number of timeouts and lock competition, and is rarely used in practical applications.
Generally speaking, the higher the isolation level of a transaction, the better it can ensure the integrity and consistency of the database. However, relatively speaking, the higher the isolation level, the greater the impact on concurrency performance. Therefore, the isolation level of the database is usually set to Read Committed, which means reading committed data, which can prevent dirty reads and provide better concurrency performance. Although this isolation level can lead to concurrency problems such as non-repeatable reads, phantom reads, and type 2 lost updates, they can be controlled by using pessimistic and optimistic locking in the application.
Related free learning recommendations: mysql video tutorial
The above is the detailed content of What are the database transaction isolation levels?. For more information, please follow other related articles on the PHP Chinese website!

MySQLstringtypesimpactstorageandperformanceasfollows:1)CHARisfixed-length,alwaysusingthesamestoragespace,whichcanbefasterbutlessspace-efficient.2)VARCHARisvariable-length,morespace-efficientbutpotentiallyslower.3)TEXTisforlargetext,storedoutsiderows,

MySQLstringtypesincludeVARCHAR,TEXT,CHAR,ENUM,andSET.1)VARCHARisversatileforvariable-lengthstringsuptoaspecifiedlimit.2)TEXTisidealforlargetextstoragewithoutadefinedlength.3)CHARisfixed-length,suitableforconsistentdatalikecodes.4)ENUMenforcesdatainte

MySQLoffersvariousstringdatatypes:1)CHARforfixed-lengthstrings,2)VARCHARforvariable-lengthtext,3)BINARYandVARBINARYforbinarydata,4)BLOBandTEXTforlargedata,and5)ENUMandSETforcontrolledinput.Eachtypehasspecificusesandperformancecharacteristics,sochoose

TograntpermissionstonewMySQLusers,followthesesteps:1)AccessMySQLasauserwithsufficientprivileges,2)CreateanewuserwiththeCREATEUSERcommand,3)UsetheGRANTcommandtospecifypermissionslikeSELECT,INSERT,UPDATE,orALLPRIVILEGESonspecificdatabasesortables,and4)

ToaddusersinMySQLeffectivelyandsecurely,followthesesteps:1)UsetheCREATEUSERstatementtoaddanewuser,specifyingthehostandastrongpassword.2)GrantnecessaryprivilegesusingtheGRANTstatement,adheringtotheprincipleofleastprivilege.3)Implementsecuritymeasuresl

ToaddanewuserwithcomplexpermissionsinMySQL,followthesesteps:1)CreatetheuserwithCREATEUSER'newuser'@'localhost'IDENTIFIEDBY'password';.2)Grantreadaccesstoalltablesin'mydatabase'withGRANTSELECTONmydatabase.TO'newuser'@'localhost';.3)Grantwriteaccessto'

The string data types in MySQL include CHAR, VARCHAR, BINARY, VARBINARY, BLOB, and TEXT. The collations determine the comparison and sorting of strings. 1.CHAR is suitable for fixed-length strings, VARCHAR is suitable for variable-length strings. 2.BINARY and VARBINARY are used for binary data, and BLOB and TEXT are used for large object data. 3. Sorting rules such as utf8mb4_unicode_ci ignores upper and lower case and is suitable for user names; utf8mb4_bin is case sensitive and is suitable for fields that require precise comparison.

The best MySQLVARCHAR column length selection should be based on data analysis, consider future growth, evaluate performance impacts, and character set requirements. 1) Analyze the data to determine typical lengths; 2) Reserve future expansion space; 3) Pay attention to the impact of large lengths on performance; 4) Consider the impact of character sets on storage. Through these steps, the efficiency and scalability of the database can be optimized.


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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

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

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

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

WebStorm Mac version
Useful JavaScript development tools
