Hash join: Difference between revisions

Content added Content deleted
m (→‎{{header|REXX}}: added/changed whitespace and comments.)
Line 1,399: Line 1,399:


=={{header|REXX}}==
=={{header|REXX}}==
<lang rexx>/*REXX pgm demonstrates the classic hash join algorithm for 2 relations.*/
<lang rexx>/*REXX program demonstrates the classic hash join algorithm for two relations.*/
S. = ; R. =
S. = ; R. =
S.1 = 27 'Jonah' ; R.1 = 'Jonah Whales'
S.1 = 27 'Jonah' ; R.1 = 'Jonah Whales'
S.2 = 18 'Alan' ; R.2 = 'Jonah Spiders'
S.2 = 18 'Alan' ; R.2 = 'Jonah Spiders'
S.3 = 28 'Glory' ; R.3 = 'Alan Ghosts'
S.3 = 28 'Glory' ; R.3 = 'Alan Ghosts'
S.4 = 18 'Popeye' ; R.4 = 'Alan Zombies'
S.4 = 18 'Popeye' ; R.4 = 'Alan Zombies'
S.5 = 28 'Alan' ; R.5 = 'Glory Buffy'
S.5 = 28 'Alan' ; R.5 = 'Glory Buffy'
hash.= /*initialize the hash table. */
hash.= /*initialize the hash table (array). */
do #=1 while S.#\==''; parse var S.# age name /*extract info*/
do #=1 while S.#\==''; parse var S.# age name /*extract information*/
hash.name=hash.name # /*build a hash table entry. */
hash.name=hash.name # /*build a hash table entry with its idx*/
end /*#*/ /* [↑] REXX does the heavy work.*/
end /*#*/ /* [↑] REXX does the heavy work here. */
#=#-1 /*adjust for DO loop (#) overage.*/
#=#-1 /*adjust for the DO loop (#) overage.*/
do j=1 while R.j\=='' /*process a nemesis for a name. */
do j=1 while R.j\=='' /*process a nemesis for a name element.*/
parse var R.j x nemesis /*extract name and it's nemesis. */
parse var R.j x nemesis /*extract the name and it's nemesis. */
if hash.x=='' then do /*Not in hash? Then a new name.*/
if hash.x=='' then do; #=#+1 /*Not in hash? Then a new name; bump #*/
#=#+1 /*bump the number of S entries. */
S.#=',' x /*add a new name to the S table. */
S.#=',' x /*add new name to the S table. */
hash.x=# /* " " " " " " hash " */
hash.x=# /*add new name to the hash table.*/
end /* [↑] this DO isn't used today. */
end /* [↑] this DO isn't used today.*/
do k=1 for words(hash.x); _=word(hash.x,k) /*get the pointer.*/
do k=1 for words(hash.x); _=word(hash.x,k) /*get pointer.*/
S._=S._ nemesis /*add the nemesis ──► applicable hash. */
S._=S._ nemesis /*add nemesis──► applicable hash.*/
end /*k*/
end /*k*/
end /*j*/
end /*j*/
_='─' /*character used for separater. */
_='─' /*the character used for the separator.*/
pad=left('',6-2) /*spacing used in hdr/sep/output.*/
pad=left('',6-2) /*spacing used in header and the output*/
say pad center('age',3) pad center('name',20) pad center('nemesis',30)
say pad center('age',3) pad center('name',20 } pad center('nemesis',30 )
say pad center('───',3) pad center('' ,20,_) pad center('' ,30,_)
say pad center('───',3) pad center('' ,20,_) pad center('' ,30,_)


do n=1 for #; parse var S.n age name nems /*get info. */
do n=1 for #; parse var S.n age name nems /*get information.*/
if nems=='' then iterate /*if no nemesis, then don't show.*/
if nems=='' then iterate /*No nemesis? Skip*/
say pad right(age,3) pad center(name,20) pad nems /*show an S.*/
say pad right(age,3) pad center(name,20) pad nems /*display an S. */
end /*n*/
end /*n*/
/*stick a fork in it, we're done.*/</lang>
/*stick a fork in it, we're all done. */</lang>
'''output''' using the in-code relations (data):
'''output''' using the in-code relations (data):
<pre>
<pre>