Spec-Zone .ru
спецификации, руководства, описания, API
|
In MySQL 5.6, MySQL Server can employ join buffers to execute not only inner joins without index access to the inner table, but also outer joins and semi-joins that appear after subquery flattening. Moreover, a join buffer can be effectively used when there is an index access to the inner table.
The join buffer management code slightly more efficiently utilizes join buffer space when storing the values of
the interesting row columns: No additional bytes are allocated in buffers for a row column if its value is NULL
, and the minimum number of bytes is allocated for any value of the VARCHAR
type.
The code supports two types of buffers, regular and incremental. Suppose that join buffer B1
is employed to join tables t1
and t2
and the result of
this operation is joined with table t3
using join buffer B2
:
A regular join buffer contains columns from each join operand. If B2
is a regular join buffer, each row r
put into B2
is composed of the columns of a row r1
from B1
and the
interesting columns of a matching row r2
from table t2
.
An incremental join buffer contains only columns from rows of the table produced by
the second join operand. That is, it is incremental to a row from the first operand buffer. If B2
is an incremental join buffer, it contains the interesting columns of
the row r2
together with a link to the row r1
from B1
.
Incremental join buffers are always incremental relative to a join buffer from an earlier join operation, so the
buffer from the first join operation is always a regular buffer. In the example just given, the buffer B1
used to join tables t1
and t2
must be a regular buffer.
Each row of the incremental buffer used for a join operation contains only the interesting columns of a row from
the table to be joined. These columns are augmented with a reference to the interesting columns of the matched
row from the table produced by the first join operand. Several rows in the incremental buffer can refer to the
same row r
whose columns are stored in the previous join buffers
insofar as all these rows match row r
.
Incremental buffers enable less frequent copying of columns from buffers used for previous join operations. This provides a savings in buffer space because in the general case a row produced by the first join operand can be matched by several rows produced by the second join operand. It is unnecessary to make several copies of a row from the first operand. Incremental buffers also provide a savings in processing time due to the reduction in copying time.
As of MySQL 5.6.3, the block_nested_loop
and batched_key_access
flags of the optimizer_switch
system variable control how the optimizer uses the Block Nested-Loop and Batched Key Access join algorithms. By
default, block_nested_loop
is on
and batched_key_access
is off
. See Section
8.8.5.2, "Controlling Switchable Optimizations".
Before MySQL 5.6.3, the optimizer_join_cache_level
system variable controls join buffer management. For
the possible values of this variable and their meanings, see the description in Section
5.1.4, "Server System Variables".
For information about semi-join strategies, see Section 8.13.16.1, "Optimizing Subqueries with Semi-Join Transformations"