Table of Contents
Today, let’s take a look at the execution process of an update statement with the mysql video tutorial column. " >Today, let’s take a look at the execution process of an update statement with the mysql video tutorial column.
Home Database Mysql Tutorial How SQL is executed in MySQL database

How SQL is executed in MySQL database

Nov 09, 2020 pm 05:20 PM
mysql database sql

Today, let’s take a look at the execution process of an update statement with the mysql video tutorial column.

How SQL is executed in MySQL database

A set of execution processes for query statements and update statements will also go through the same step. Below we compare it with the previous article Let’s take a brief look at the picture:

<img src=" data- style="max-width:90%" data- style="max-width:90%">

First of all, you need to connect to the database before executing the statement. This is the job of the connector in the first step. We also said before, When a table is updated, the query cache related to this table will become invalid, so we generally do not recommend October query cache.

Next, the analyzer will go through syntax analysis and lexical analysis. After knowing that this is an update statement, the optimizer decides which index to use, and then the executor is responsible for the specific execution. First find this line, Then do the update.

Different from the query statement update, the update process also involves two important logs. We have also introduced this in the previous article. If you are interested, you can find last week's article "MySQL's Two "A Log System", I won’t introduce it much here.

Let’s analyze the update operation process through a simple example.

We first create a table with a primary key ID and an integer field c:

mysql> create table demo T (ID int primarty ,c int);复制代码
Copy after login

Then add 1 to the value of the row with ID=2

mysql> update table demo set c = c + 1 where ID = 2;复制代码
Copy after login

Next, let’s take a look at the execution process of the update statement. The light box in the figure represents the execution in the storage engine, and the colored box represents the execution in the executor.

We can see that at the end, there are two steps when writing redolog, prepare and commit. This is what we often call "two-phase commit".

Why does the log need "two-phase submission"?

Since redo log and binlog are the logs of the storage engine and the executor respectively, they are two independent logics. If two-stage submission is not used, there will be some problems no matter which one is submitted first and which one is submitted later. Let's take a look at the example above. Assume that the current value of the row with ID=2 is 0. After the first log is written during the update process, a crash occurs while the second log is not written. What will happen? ?

  • Write redolog first and then binlog. Assume that the redolog has been written but the binlog has not yet been written, and the MySQL process restarts abnormally. We know that after the redolog is written, the data can be restored even if the system crashes, so after MySQL is restarted, this row will be restored to 1. Since the binlog crashes before it is finished, there is no such statement in the binlog at this time. Therefore, when the log is backed up later, the saved binlog log does not have this statement. When we need to restore data through binlog, because binlog has lost this statement, the value of the restored row is 0, which is different from the value of the original database.
  • Write binlog first and then redo log. If after writing the buglog, a crash occurs before the redo log is completed, and if the database crashes at this time, the transaction will be invalid after recovery, so the value of this line is still 0, but the update statement has been recorded in the binlog. Log, when you need to use binlog to restore data in the future, there will be an additional transaction. Execute this update statement to update the value from 0 to 1, which is different from the 0 in the original database.

We can see that if "two-phase commit" is not used, the state of the database will be inconsistent with the database restored using logs. Although the probability of using logs to recover data is relatively low, the most common use of logs is during capacity expansion, which is achieved through full backup and binlog. This may lead to inconsistencies between the online master-slave databases.

Related free learning recommendations: mysql video tutorial

The above is the detailed content of How SQL is executed in MySQL database. For more information, please follow other related articles on the PHP Chinese website!

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)
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
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)

What is the difference between HQL and SQL in Hibernate framework? What is the difference between HQL and SQL in Hibernate framework? Apr 17, 2024 pm 02:57 PM

HQL and SQL are compared in the Hibernate framework: HQL (1. Object-oriented syntax, 2. Database-independent queries, 3. Type safety), while SQL directly operates the database (1. Database-independent standards, 2. Complex executable queries and data manipulation).

Usage of division operation in Oracle SQL Usage of division operation in Oracle SQL Mar 10, 2024 pm 03:06 PM

"Usage of Division Operation in OracleSQL" In OracleSQL, division operation is one of the common mathematical operations. During data query and processing, division operations can help us calculate the ratio between fields or derive the logical relationship between specific values. This article will introduce the usage of division operation in OracleSQL and provide specific code examples. 1. Two ways of division operations in OracleSQL In OracleSQL, division operations can be performed in two different ways.

Comparison and differences of SQL syntax between Oracle and DB2 Comparison and differences of SQL syntax between Oracle and DB2 Mar 11, 2024 pm 12:09 PM

Oracle and DB2 are two commonly used relational database management systems, each of which has its own unique SQL syntax and characteristics. This article will compare and differ between the SQL syntax of Oracle and DB2, and provide specific code examples. Database connection In Oracle, use the following statement to connect to the database: CONNECTusername/password@database. In DB2, the statement to connect to the database is as follows: CONNECTTOdataba

Detailed explanation of the Set tag function in MyBatis dynamic SQL tags Detailed explanation of the Set tag function in MyBatis dynamic SQL tags Feb 26, 2024 pm 07:48 PM

Interpretation of MyBatis dynamic SQL tags: Detailed explanation of Set tag usage MyBatis is an excellent persistence layer framework. It provides a wealth of dynamic SQL tags and can flexibly construct database operation statements. Among them, the Set tag is used to generate the SET clause in the UPDATE statement, which is very commonly used in update operations. This article will explain in detail the usage of the Set tag in MyBatis and demonstrate its functionality through specific code examples. What is Set tag Set tag is used in MyBati

What does the identity attribute in SQL mean? What does the identity attribute in SQL mean? Feb 19, 2024 am 11:24 AM

What is Identity in SQL? Specific code examples are needed. In SQL, Identity is a special data type used to generate auto-incrementing numbers. It is often used to uniquely identify each row of data in a table. The Identity column is often used in conjunction with the primary key column to ensure that each record has a unique identifier. This article will detail how to use Identity and some practical code examples. The basic way to use Identity is to use Identit when creating a table.

PHP development practice: Use PHPMailer to send emails to users in the MySQL database PHP development practice: Use PHPMailer to send emails to users in the MySQL database Aug 05, 2023 pm 06:21 PM

PHP development practice: Use PHPMailer to send emails to users in the MySQL database Introduction: In the construction of the modern Internet, email is an important communication tool. Whether it is user registration, password reset, or order confirmation in e-commerce, sending emails is an essential function. This article will introduce how to use PHPMailer to send emails and save the email information to the user information table in the MySQL database. 1. Install the PHPMailer library PHPMailer is

How to solve the 5120 error in SQL How to solve the 5120 error in SQL Mar 06, 2024 pm 04:33 PM

Solution: 1. Check whether the logged-in user has sufficient permissions to access or operate the database, and ensure that the user has the correct permissions; 2. Check whether the account of the SQL Server service has permission to access the specified file or folder, and ensure that the account Have sufficient permissions to read and write the file or folder; 3. Check whether the specified database file has been opened or locked by other processes, try to close or release the file, and rerun the query; 4. Try as administrator Run Management Studio as etc.

How to use SQL statements for data aggregation and statistics in MySQL? How to use SQL statements for data aggregation and statistics in MySQL? Dec 17, 2023 am 08:41 AM

How to use SQL statements for data aggregation and statistics in MySQL? Data aggregation and statistics are very important steps when performing data analysis and statistics. As a powerful relational database management system, MySQL provides a wealth of aggregation and statistical functions, which can easily perform data aggregation and statistical operations. This article will introduce the method of using SQL statements to perform data aggregation and statistics in MySQL, and provide specific code examples. 1. Use the COUNT function for counting. The COUNT function is the most commonly used

See all articles