MySQL uses SELECT... FOR UPDATE to confirm before transaction writing
Take MySQL's InnoDB as an example. The default Tansaction isolation level is REPEATABLE READ. There are two main types of read locks in SELECT. Method:
SELECT … LOCK IN SHARE MODE SELECT … FOR UPDATE
These two methods must wait for other transaction data to be submitted (Commit) before executing when SELECTing to the same data table is in progress. The main difference is that LOCK IN SHARE MODE can easily cause deadlock when one party wants to update the same form.
Simply put, if you want to UPDATE the same form after SELECT, it is best to use SELECT ... UPDATE.
For example: Suppose there is a quantity in the product form products to store the quantity of the product. Before the order is established, it must be determined whether the quantity of the product is sufficient (quantity>0), and then the quantity is updated to 1.
Unsafe practices:
1 SELECT quantity FROM products WHERE id=3; 1 UPDATE products SET quantity = 1 WHERE id=3;
Why is it unsafe?
There may not be a problem in a small amount of cases, but a large amount of data access will "definitely" cause problems.
If we need to deduct inventory when quantity>0, assuming that the quantity read by the program in the first line of SELECT is 2, it seems that the number is correct, but when MySQL is preparing to UPDATE, Someone may have deducted the inventory to 0, but the program didn't know it and made the wrong UPDATE.
Therefore, the transaction mechanism must be used to ensure that the data read and submitted are correct.
So we can test like this in MySQL: (Note 1)
1 SET AUTOCOMMIT=0; 2 BEGIN WORK; 3 SELECT quantity FROM products WHERE id=3 FOR UPDATE;
At this time, the data with id=3 in the products data is locked (Note 3), other transactions must wait for this transaction to be committed before executing SELECT * FROM products WHERE id=3 FOR UPDATE (Note 2) This ensures that the number read by quantity in other transactions is correct.
1 UPDATE products SET quantity = '1' WHERE id=3 ; 2 COMMIT WORK;
Commit is written to the database and products are unlocked.
Note 1: BEGIN/COMMIT is the starting and ending point of the transaction. You can use more than two MySQL Command windows to interactively observe the locking status.
Note 2: During the transaction, only SELECT... FOR UPDATE or LOCK IN SHARE MODE for the same data will wait for the completion of other transactions before executing. Generally, SELECT... will not be affected by this.
Note 3: Since InnoDB defaults to Row-level Lock, please refer to this article for locking data columns.
Note 4: Try not to use the LOCK TABLES instruction in InnoDB forms. If you have to use it as a last resort, please read the official instructions for using LOCK TABLES in InnoDB to avoid frequent deadlocks in the system.
The above is the content of Mysql high-concurrency locking transaction processing. For more related content, please pay attention to the PHP Chinese website (www.php.cn)!

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。


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

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Atom editor mac version download
The most popular open source editor

Dreamweaver Mac version
Visual web development tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 English version
Recommended: Win version, supports code prompts!
