I'm trying to see if my understanding of JOINs
is correct.
For the following query:
SELECT * FROM tableA
join tableB on tableA.someId = tableB.someId
join tableC on tableA.someId = tableC.someId;
Does the RDMS basically execute similar pseudocode as follows:
List tempResults
for each A_record in tableA
for each B_record in tableB
if (A_record.someId = B_record.someId)
tempResults.add(A_record)
List results
for each Temp_Record in tempResults
for each C_record in tableC
if (Temp_record.someId = C_record.someId)
results.add(C_record)
return results;
So basically the more records with the same someId
tableA
has with tableB
and tableC
, the more records the RDMS have the scan? If all 3 tables have records with same someId
, then essentially a full table scan is done on all 3 tables?
Is my understanding correct?