This is the 7th day of my participation in the August Text Challenge.More challenges in August
Preface: This article is my seventh article about MySQL, the level is general, ability is limited. The article is relatively shallow, suitable for novice. The last article covered the origin of transactions, and this article covers the isolation level of transactions.
Introduction to isolation levels
As mentioned in the previous article about MySQL isolation, transactions are normally invisible to other connections while they are not completed. In general, however, there are four isolation levels specified in the SQL standard, each with a different level of visibility allowed between transactions. (Each storage engine also implements slightly different isolation levels)
The lower the isolation level, the higher the concurrency that can be performed and the higher the performance. Conversely, higher isolation levels lead to lower concurrency and performance.
Ii. Isolation level details
1.READ UNCOMMITTED
A transaction that is in progress but has not yet been committed can be Read. This is also known as Dirty reads. It is dangerous to read data that a connection is modifying before committing it. And there’s not much performance improvement. Generally not used in development application scenarios.
2. READ COMMITTED
As the name implies, only transactions that have already been executed can be read. This is the transaction isolation level used by most databases, such as Oracle. But MySQL does not use this isolation level. This isolation level is also known as unrepeatable reads.
REPEATABLE READ = REPEATABLE READ
MySQL uses the default level. Query results are the same before and after a transaction.
4. SERIALIZABLE
Isolation levels that are less commonly used.
I’m too difficult. There’s a power outage. I can only write on my phone.