Nested loop join
Find sources: "Nested loop join" – news · newspapers · books · scholar · JSTOR (January 2021) (Learn how and when to remove this message)
A nested loop join is a naive algorithm that joins two relations by using two nested loops.[1] Join operations are important for database management.
Algorithm
[edit ]Two relations {\displaystyle R} and {\displaystyle S} are joined as follows:
algorithm nested_loop_join is for each tuple r in R do for each tuple s in S do if r and s satisfy the join condition then yield tuple <r,s>
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 {\displaystyle O(|R||S|)} I/Os, where {\displaystyle |R|} and {\displaystyle |S|} is the number of tuples contained in {\displaystyle R} and {\displaystyle S} respectively and can easily be generalized to join any number of relations ...
The block nested loop join algorithm[2] is a generalization of the simple nested loops algorithm that takes advantage of additional memory to reduce the number of times that the {\displaystyle S} relation is scanned. It loads large chunks of relation R into main memory. For each chunk, it scans S and evaluates the join condition on all tuple pairs, currently in memory. This reduces the number of times S is scanned to once per chunk.
Index join variation
[edit ]If the inner relation has an index on the attributes used in the join, then the naive nest loop join can be replaced with an index join.
algorithm index_join is for each tuple r in R do for each tuple s in S in the index lookup do yield tuple <r,s>
The time complexity for this variation improves from {\displaystyle O(|R||S|){\text{ to }}O(|R|\log |S|)}
See also
[edit ]References
[edit ]- ^ "Understanding Nested Loops Joins". 4 October 2012.
- ^ "Query Processing Overview" (PDF). Archived from the original (PDF) on 2021年07月30日.
This computer science article is a stub. You can help Wikipedia by expanding it.