Hash Join - Grace Hash Join

Grace Hash Join

A better approach is known as the "grace hash join", after the GRACE database machine for which it was first implemented. This algorithm avoids rescanning the entire relation by first partitioning both and via a hash function, and writing these partitions out to disk. The algorithm then loads pairs of partitions into memory, builds a hash table for the smaller partitioned relation, and probes the other relation for matches with the current hash table. Because the partitions were formed by hashing on the join key, it must be the case that any join output tuples must belong to the same partition. It is possible that one or more of the partitions still does not fit into the available memory, in which case the algorithm is recursively applied: an additional orthogonal hash function is chosen to hash the large partition into sub-partitions, which are then processed as before. Since this is expensive, the algorithm tries to reduce the chance that it will occur by forming as many partitions as possible during the initial partitioning phase.

Read more about this topic:  Hash Join

Famous quotes containing the words grace and/or join:

    I give thanks to my God always for you because of the grace of God that has been given you in Christ Jesus...
    Bible: New Testament, 1 Corinthians 1:4.

    Business by no means forbids pleasures; on the contrary, they reciprocally season each other; and I will venture to affirm that no man enjoys either in perfection that does not join both.
    Philip Dormer Stanhope, 4th Earl Chesterfield (1694–1773)