The
InnoDB
Transaction Model and Locking
1270
(negative infinity, 10]
(10, 11]
(11, 13]
(13, 20]
(20, positive infinity)
For the last interval, the next-key lock locks the gap above the largest value in the index and the
“supremum” pseudo-record having a value higher than any value actually in the index. The supremum
is not a real index record, so, in effect, this next-key lock locks only the gap following the largest index
value.
The preceding example shows that a gap might span a single index value, multiple index values, or
even be empty.
Gap locking is not needed for statements that lock rows using a unique index to search for a unique
row. (This does not include the case that the search condition includes only some columns of a
multiple-column unique index; in that case, gap locking does occur.) For example, if the
id
column has
a unique index, the following statement uses only an index-record lock for the row having
id
value 100
and it does not matter whether other sessions insert rows in the preceding gap:
SELECT * FROM child WHERE id = 100;
If
id
is not indexed or has a nonunique index, the statement does lock the preceding gap.
A type of gap lock called an insertion intention gap lock is set by
INSERT
operations prior to row
insertion. This lock signals the intent to insert in such a way that multiple transactions inserting into
the same index gap need not wait for each other if they are not inserting at the same position within
the gap. Suppose that there are index records with values of 4 and 7. Separate transactions that
attempt to insert values of 5 and 6 each lock the gap between 4 and 7 with insert intention locks prior
to obtaining the exclusive lock on the inserted row, but do not block each other because the rows are
nonconflicting.
Gap locking can be disabled explicitly. This occurs if you change the transaction isolation level to
READ
COMMITTED
[1121]
or enable the
innodb_locks_unsafe_for_binlog
[1244]
system variable.
Under these circumstances, gap locking is disabled for searches and index scans and is used only for
foreign-key constraint checking and duplicate-key checking.
There is also another effect of using the
READ COMMITTED
[1121]
isolation level or enabling
innodb_locks_unsafe_for_binlog
[1244]
: Record locks for nonmatching rows are released after
MySQL has evaluated the
WHERE
condition.
14.2.7.5. Avoiding the Phantom Problem Using Next-Key Locking
The so-called phantom problem occurs within a transaction when the same query produces different
sets of rows at different times. For example, if a
SELECT
is executed twice, but returns a row the
second time that was not returned the first time, the row is a “phantom” row.
Suppose that there is an index on the
id
column of the
child
table and that you want to read and lock
all rows from the table having an identifier value larger than 100, with the intention of updating some
column in the selected rows later:
SELECT * FROM child WHERE id > 100 FOR UPDATE;
The query scans the index starting from the first record where
id
is bigger than 100. Let the table
contain rows having
id
values of 90 and 102. If the locks set on the index records in the scanned
range do not lock out inserts made in the gaps (in this case, the gap between 90 and 102), another
session can insert a new row into the table with an
id
of 101. If you were to execute the same
SELECT
within the same transaction, you would see a new row with an
id
of 101 (a “phantom”) in the result set
returned by the query. If we regard a set of rows as a data item, the new phantom child would violate
the isolation principle of transactions that a transaction should be able to run so that the data it has
read does not change during the transaction.
Summary of Contents for 5.0
Page 1: ...MySQL 5 0 Reference Manual ...
Page 18: ...xviii ...
Page 60: ...40 ...
Page 396: ...376 ...
Page 578: ...558 ...
Page 636: ...616 ...
Page 844: ...824 ...
Page 1234: ...1214 ...
Page 1427: ...MySQL Proxy Scripting 1407 ...
Page 1734: ...1714 ...
Page 1752: ...1732 ...
Page 1783: ...Configuring Connector ODBC 1763 ...
Page 1793: ...Connector ODBC Examples 1773 ...
Page 1839: ...Connector Net Installation 1819 2 You must choose the type of installation to perform ...
Page 2850: ...2830 ...
Page 2854: ...2834 ...
Page 2928: ...2908 ...
Page 3000: ...2980 ...
Page 3122: ...3102 ...
Page 3126: ...3106 ...
Page 3174: ...3154 ...
Page 3232: ...3212 ...