Using Buffer UPDATE Algorithm
This article explains the UPDATE
statement's Using Buffer algorithm.
Take the following table and query:
Name | Salary |
---|---|
Babatunde | 1000 |
Jolana | 1050 |
Pankaja | 1300 |
UPDATE employees SET salary = salary+100 WHERE salary < 2000;
Suppose the employees table has an index on the salary column, and the optimizer decides to use a range scan on that index.
The optimizer starts a range scan on the salary index. We find the first record Babatunde, 1000. If we do an on-the-fly update, we immediately instruct the storage engine to change this record to be Babatunde, 1000+100=1100.
Then we proceed to search for the next record, and find Jolana, 1050. We instruct the storage engine to update it to be Jolana, 1050+100=1150.
Then we proceed to search for the next record ... and what happens next depends on the storage engine. In some storage engines, data changes are visible immediately, so we will find find the Babatunde, 1100 record that we wrote at the first step, modifying it again, giving Babatunde an undeserved raise. Then we will see Babatunde again and again, looping continually.
In order to prevent such situations, the optimizer checks whether the UPDATE statement is going to change key values for the keys it is using. In that case, it will use a different algorithm:
- Scan everyone with "salary<2000", remembering the rowids of the rows in a buffer.
- Read the buffer and apply the updates.
This way, each row will be updated only once.
The Using buffer
EXPLAIN
output indicates that the buffer as described above will be used. The algorithm has always been in use, but has only been made visible in the EXPLAIN
output since MariaDB 10.0.5.
© 2021 MariaDB
Licensed under the Creative Commons Attribution 3.0 Unported License and the GNU Free Documentation License.
https://mariadb.com/kb/en/using-buffer-update-algorithm/