Home Database Mysql Tutorial 【终身难忘的记忆法】事务隔离级别

【终身难忘的记忆法】事务隔离级别

Jun 07, 2016 pm 03:57 PM
affairs level isolation

前几天看spring3.x的时候,看到了事务隔离级别那,提到这就要提到五种常见的事务并发问题,就是大家耳熟能详的脏读、幻读、不可重复读、第一类更新丢失、第二类更新丢失。那么今天我就主要来讲最常用的前三类问题,当然,是用最易懂的方式。 首先,什么是脏

前几天看spring3.x的时候,看到了事务隔离级别那,提到这就要提到五种常见的事务并发问题,就是大家耳熟能详的脏读、幻读、不可重复读、第一类更新丢失、第二类更新丢失。那么今天我就主要来讲最常用的前三类问题,当然,是用最易懂的方式。

首先,什么是脏读?

学术解释:脏读就是指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据。

我的解释:你正在做菜,把切好的菜放在一边准备下锅,这时候,妻子告诉你开饭了,然后端着你这堆还没下锅的菜就放到了餐桌上。

什么是不可重复读?

学术解释:不可重复读:是指在一个事务内,多次读同一数据。在这个事务还没有结束时,另外一个事务也访问该同一数据。那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,那么第一个事务两次读到的的数据可能是不一样的。这样在一个事务内两次读到的数据是不一样的,因此称为是不可重复读。

我的解释:当你是一个乐队的指挥,当第一乐章的小提琴独奏开始时,你觉得他非常美妙; 可到了第二乐章小提琴独奏的时候,你发现他消失了,观众告诉你他中途上厕所去了,还没回来。

什么是幻读?

学术解释:是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么,以后就会发生操作第一个事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样。

我的解释:我同“不可重复读”用同一个场景,当你在演奏第一乐章的时候,你觉得音乐非常美妙,但到了第二乐章的时候,你突然感觉音乐出现了不和谐的声音,然后你发现,乐队突然多了一个鼓手。

不可重复读和幻读的区别?

不可重复读是指你第一次注意乐队里的一个人,第二次看到他时,出现了变化。

幻读是指,你第一次注意的由很多人组成的乐队,当第一次看到这支乐队时,乐队多了一个人。

不可重复读针对的是个人,一条数据。

幻读针对的是集合、多条数据。

最后提一下事务的四个隔离级别,要注意自上而下的顺序,并发速度可是递减的哦。

MySQL5 默认的事务隔离级别为:REPEATABLE-READ

查看 MySQL5 的事务隔离级别:select @@select @@tx_isolation;

修改 MySQL5 的事务隔离级别:set transaction isolation level read committed;

\

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

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Lock wait timeout exceeded; try restarting transaction - How to solve MySQL error: transaction wait timeout Lock wait timeout exceeded; try restarting transaction - How to solve MySQL error: transaction wait timeout Oct 05, 2023 am 08:46 AM

Lockwaittimeoutexceeded;tryrestartingtransaction - How to solve the MySQL error: transaction wait timeout. When using the MySQL database, you may sometimes encounter a common error: Lockwaittimeoutexceeded;tryrestartingtransaction. This error indicates that the transaction wait timeout. This error usually occurs when

MySQL transaction processing: the difference between automatic submission and manual submission MySQL transaction processing: the difference between automatic submission and manual submission Mar 16, 2024 am 11:33 AM

MySQL transaction processing: the difference between automatic submission and manual submission. In the MySQL database, a transaction is a set of SQL statements. Either all executions are successful or all executions fail, ensuring the consistency and integrity of the data. In MySQL, transactions can be divided into automatic submission and manual submission. The difference lies in the timing of transaction submission and the scope of control over the transaction. The following will introduce the difference between automatic submission and manual submission in detail, and give specific code examples to illustrate. 1. Automatically submit in MySQL, if it is not displayed

Detailed explanation of the location of win10 virus isolation Detailed explanation of the location of win10 virus isolation Dec 25, 2023 pm 01:45 PM

Files isolated by Win10 viruses are generally stored in fixed locations. Many users want to open the quarantined files and restore their own files, but they don’t know where they are stored. In fact, they can usually be found in the isolation folder of the C drive security software. Where is the win10 virus quarantine file? Answer: In the C:\ProgramData\Microsoft\WindowsDefender\Quarantine folder, we can open this computer and directly copy and paste the file path to the path bar above to find it. Introduction to the virus isolation folder in win10: 1. In win10, the "Quarantine" file usually requires certain permissions to open. It is recommended to open the file as an administrator. 2,

The principles and application scenarios of MySQL transactions The principles and application scenarios of MySQL transactions Mar 02, 2024 am 09:51 AM

The principle and application scenarios of MySQL transactions In the database system, a transaction is a set of SQL operations. These operations are either all executed successfully or all fail and are rolled back. As a commonly used relational database management system, MySQL supports transaction characteristics and can ensure that the data in the database is consistent, isolated, durable and atomic. This article will start with the basic principles of MySQL transactions, introduce its application scenarios, and provide specific code examples for readers' reference. The principle of MySQL transactions: My

How does Java database connection handle transactions and concurrency? How does Java database connection handle transactions and concurrency? Apr 16, 2024 am 11:42 AM

Transactions ensure database data integrity, including atomicity, consistency, isolation, and durability. JDBC uses the Connection interface to provide transaction control (setAutoCommit, commit, rollback). Concurrency control mechanisms coordinate concurrent operations, using locks or optimistic/pessimistic concurrency control to achieve transaction isolation to prevent data inconsistencies.

PHP PDO Tutorial: An Advanced Guide from Basics to Mastery PHP PDO Tutorial: An Advanced Guide from Basics to Mastery Feb 19, 2024 pm 06:30 PM

1. Introduction to PDO PDO is an extension library of PHP, which provides an object-oriented way to operate the database. PDO supports a variety of databases, including Mysql, postgresql, oracle, SQLServer, etc. PDO enables developers to use a unified API to operate different databases, which allows developers to easily switch between different databases. 2. PDO connects to the database. To use PDO to connect to the database, you first need to create a PDO object. The constructor of the PDO object receives three parameters: database type, host name, database username and password. For example, the following code creates an object that connects to a mysql database: $dsn="mysq

Master the power of PHP PDO: advanced queries and updates Master the power of PHP PDO: advanced queries and updates Feb 20, 2024 am 08:24 AM

The PHP Data Objects (PDO) extension provides efficient and object-oriented interaction with database servers. Its advanced query and update capabilities enable developers to perform complex database operations, improving performance and code maintainability. This article will delve into the advanced query and update functions of PDO and guide you to master its powerful functions. Advanced queries: Using placeholders and bound parameters Placeholders and bound parameters are important tools for improving query performance and security. Placeholders use question marks (?) to represent replaceable parameters in the query, while bind parameters allow you to specify the data type and value of each parameter. By using these methods, you can avoid SQL injection attacks and improve performance because the database engine can optimize queries ahead of time. //Use placeholder $stmt=$

PHP transaction error locating and repair methods PHP transaction error locating and repair methods Mar 23, 2024 am 11:09 AM

PHP transaction error locating and repair methods During the development process, we often involve database operations. In order to ensure the integrity and consistency of data, when processing database operations, we often use transactions to ensure the atomicity of a series of operations. However, in the actual development process, sometimes errors occur in transactions, resulting in incomplete or inconsistent data operations. This article will introduce how to locate and fix transaction errors in PHP, while providing specific code examples. To locate transaction errors in PHP, we can use MySQLi or

See all articles