Example verification MySQL | update field with the same value will record binlog

Example verification MySQL | update field with the same value will record binlog

1. Introduction

A few days ago, a development colleague asked me whether updating a field to the same value would record binlog. I replied that it would not.

Strictly speaking, this answer is inaccurate, as it is necessary to distinguish between scenarios. Whether to record update statements in binlog depends on the setting of binlog_format. Practice makes perfect in specific situations.

Second test

2.1 binlog_format is ROW mode

2.2 binlog_format is in STATEMENT mode

Parse the binlog content and record the update statement completely.

2.2 binlog_format is in MIXED mode

When row_format is mixed or statement format, the size of the binlog changes. Regardless of whether the data is actually updated, MySQL records the executed SQL to the binlog.

Three conclusions

In row-based mode, the server layer matches the record to be updated and finds that the new value is consistent with the old value. It does not update the record and returns directly without recording the binlog.

Based on the statement or mixed format, MySQL executes the update statement and records the update statement to the binlog.

So why do statement and mixed record the complete SQL statement? I will explain this in the next article, because I need to parse the source code and have not yet succeeded in compiling the MySQL debugging environment using Clion.

The above is an example to verify whether the MySQL|update field will record the details of the binlog when it has the same value. For more information about the MySQL update field, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • MySQL update fields from one table to another
  • MySQL UPDATE statement to replace part of the content in a field
  • Detailed analysis of the syntax of Mysql update to modify multiple fields and

<<:  Alibaba Cloud Nginx configures https to implement domain name access project (graphic tutorial)

>>:  Pull-down refresh and pull-up loading components based on Vue encapsulation

Recommend

How to remove the header from the element table

Document hints using the show-header attribute sh...

Detailed explanation of how two Node.js processes communicate

Table of contents Preface Communication between t...

Solve the problem of black screen when starting VMware virtual machine

# Adjust VMware hard disk boot priority Step 1: E...

CSS text alignment implementation code

When making forms, we often encounter the situati...

Detailed tutorial on installing harbor private warehouse using docker compose

Overview What is harbor? The English word means: ...

JavaScript source code for Elimination

JavaScript to achieve the source code download ad...

Mini Programs enable product attribute selection or specification selection

This article shares the specific code for impleme...

Summary of JavaScript custom object methods

Table of contents 1. Use object to create an obje...

JavaScript Timer Details

Table of contents 1. Brief Introduction 2. setInt...

How to display percentage and the first few percent in MySQL

Table of contents Require Implementation Code dat...

React tsx generates random verification code

React tsx generates a random verification code fo...

How to clean up the disk space occupied by Docker

Docker takes up a lot of space. Whenever we run c...

Detailed explanation of how to use the vue verification code component

This article example shares the specific implemen...

Three common uses of openlayers6 map overlay (popup window marker text)

Table of contents 1. Write in front 2. Overlay to...