| Example PostgreSQL Execution (cont)
Execution:ExecutePlan()repeatedly invokesExecProcNode().
ExecProcNode()sees aNestedLoopnode ...so dispatches to
 ExecNestedLoop()to get next tuplewhich invokes
 ExecProcNode()on its sub-plansin left sub-plan,
 ExecProcNode()sees anIndexScannodeso dispatches to
 ExecIndexScan()to get next tupleif no more tuples, return END
 for this tuple, invoke
 ExecProcNode()on right sub-plan
 ExecProcNode()sees aSeqScannodeso dispatches to
 ExecSeqScan()to get next tuplecheck for match and return joined tuples if found
 continue scan until end
 reset right sub-plan iterator
 
 
Result: stream of result tuples returned via ExecutePlan() |