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:

    Humans need justice in the here and now and grace in the thereafter. Justice in the here and now is possible only without freedom, and grace in the thereafter only through the freedom of God.
    Friedrich Dürrenmatt (1921–1990)

    This fellow will but join you together as they join
    wainscot; then one of you will prove a shrunk panel, and
    like green timber warp, warp.
    William Shakespeare (1564–1616)