data:image/s3,"s3://crabby-images/ca364/ca36463f9b82c90b6f3e27c6326cdcdc31617e4c" alt=""
Nested loop join
Encyclopedia
A nested loop join is a naive algorithm
that joins two relations
and
by making two nested loops:
For each tuple r in R do
For each tuple s in S do
If r and s satisfy the join condition
Then output the tuple
This algorithm will involve nr*bs+ br block transfers and nr+br seeks. Where br and bs are number of blocks in relations r and s respectively, and nr is the number of tuples in relation r.
The algorithm runs in
I/Os, where
and
is the number of tuples contained in
and
respectively. Can easily be generalized to join any number of relations.
The block nested loop
join algorithm is a generalization of the simple nested loops algorithm that takes advantage of additional memory to reduce the number of times that the
relation is scanned.
, the relation
can be read only once.
For each block block_r in R do
For each tuple s in S do
For each tuple r in block_r do
If r and s satisfy the join condition
Then output the tuple
Variable block_r is stored in memory, thus it is not needed to read it from disk for each tuple
.
Algorithm
In mathematics and computer science, an algorithm is an effective method expressed as a finite list of well-defined instructions for calculating a function. Algorithms are used for calculation, data processing, and automated reasoning...
that joins two relations
data:image/s3,"s3://crabby-images/2b039/2b039352900b107cf61568cf027a9f2124c10dc9" alt=""
data:image/s3,"s3://crabby-images/ed40e/ed40e7e231b5460543cb2039404d3d3f5d2c51e0" alt=""
For each tuple r in R do
For each tuple s in S do
If r and s satisfy the join condition
Then output the tuple
This algorithm will involve nr*bs+ br block transfers and nr+br seeks. Where br and bs are number of blocks in relations r and s respectively, and nr is the number of tuples in relation r.
The algorithm runs in
data:image/s3,"s3://crabby-images/2a4c1/2a4c1b22a776fcc1cbe9db99d9684d8b24fe2305" alt=""
data:image/s3,"s3://crabby-images/8c0e1/8c0e1b93f2f564635e635ccc273c7e586cc549e5" alt=""
data:image/s3,"s3://crabby-images/c6025/c6025228202bdc7a837b9bb8efb8ec1fc17a85de" alt=""
data:image/s3,"s3://crabby-images/2b061/2b061c930c63aae8f3e5481fbf5c51725441d3ef" alt=""
data:image/s3,"s3://crabby-images/e37a2/e37a202ff2a22ad20a43098c2871140d945ae827" alt=""
The block nested loop
Block nested loop
A block-nested loop is an algorithm used to join two relations in a relational database.This algorithm is a variation on the simple nested loop join used to join two relations R and S...
join algorithm is a generalization of the simple nested loops algorithm that takes advantage of additional memory to reduce the number of times that the
data:image/s3,"s3://crabby-images/97dfd/97dfd756e14f94f266956518a65b6442af258777" alt=""
Improved version
The algorithm can be improved without requesting additional memory blocks to involve only br*bs+ br seeks. For each read block fromdata:image/s3,"s3://crabby-images/41582/41582dc348c32e0afc02860bd37f80652c2b4339" alt=""
data:image/s3,"s3://crabby-images/5f294/5f2946daa6a3b4345a623dd616cafffc1246c8f9" alt=""
For each block block_r in R do
For each tuple s in S do
For each tuple r in block_r do
If r and s satisfy the join condition
Then output the tuple
Variable block_r is stored in memory, thus it is not needed to read it from disk for each tuple
data:image/s3,"s3://crabby-images/490b4/490b4a17b5d56e130a4f1704eec09f070e3da95a" alt=""