For example, consider the scheme below:
data:image/s3,"s3://crabby-images/58427/58427fd8b8d17be6d54fb4ed925a3792a72e112d" alt=""
CROSSJOIN
Whenwewanttojointwoormoretablesbycrossing.Thatis,foreachrowoftheFUNCTIONALtablewewantalltheCHARGESorviceversa.
data:image/s3,"s3://crabby-images/951ad/951adbee90827b983cf2aae133c15096e3494f9b" alt=""
INNERJOIN
Whenwewanttojointwoormoretablesbycoincidence.ForeachrowoftheFUNCINARYtablewewantthecorrespondingPOSITIONthatinternally(INNER),intheirattributevalues,match.InthecaseofFUNIONARYandCHARGEthematchinginternalattributesarecodeIngintheTABLEtableandcodeIngintheFUNCTIONALtable.Tocombinethetwotables,itwillbenecessarytoconnectthetwotablesbytheirmatchinginternalattributes(INNER).
data:image/s3,"s3://crabby-images/27031/2703177399239424304d64e33edb619acf0d312d" alt=""
LEFTOUTERJOIN
LookingattheFUNCTIONALtable,supposethattheemployeeTadeuhasnopositionassociatedwithit.Ifwewishtolistalltheemployeeswiththeirrespectivepositions,includingtheemployeeswithoutpositions,wecoulduseallthepoweroftheINNERJOINjunctionbyaddingOUTER(OUTS/OUTS)EmployeeswhoarenotpartofINNERJOIN,justtothosewithoutpositionslikeTadeu.WecanachievethisbyjoiningFUNCIONARIO/CARGOthroughthedeclarationOUTERLEFTJOINCARGO,whichpromotestheinternaljoining(INNER)ofallemployeestopositionsandlistsother(OUTSOURDED/OUTER)nonassociated.
Animportantobservationisthattheorderoftheconnection(ON)makesnodifference,ie:"ON (F.codCargo = C.codCargo)" is exactly equal to "ON (C.codCargo = F.codCargo)"
data:image/s3,"s3://crabby-images/f2af5/f2af5cd951ef45284f650eae1f954975768e7e34" alt=""
RIGHTOUTERJOIN
LookingattheCARGOtable,supposethemanagerposition,withcodeC3,isnotreferenced/associatedby/toanyemployeeintheOFFICIALtable.IfwewishtolistallCHARGESandtheirrespectiveOFFICERS,includingCHARGESwithoutEMPLOYEES,wecouldusetheRIGTHOUTERJOINjoin.
data:image/s3,"s3://crabby-images/5cf98/5cf985dc3c7cfd0a153cf788258b403cf27aa0ec" alt=""
OUTERFULLJOIN
Herewecombinethepowerofinternaljoins(INNER),thelistingofallothernon-associatedlines,bothontherightside(RIGHT)ofthejunctionandontheLEFTside.
data:image/s3,"s3://crabby-images/c9e55/c9e559e94207eed8f84f2ce81713e4121ba19542" alt=""
@ reference