Regardless of how you structure the query, Oracle's optimizer is free to evaluate the function before or after the join. Assuming that the string manipulation is only done as part of the projection step (i.e. it is done only in the SELECT
clause and is not used as a predicate in the WHERE
clause), I would expect that Oracle would apply the SUBSTR
before joining the tables if you used either formulation because it would then have to apply the function to fewer rows (though it can probably treat the SUBSTR
as a deterministic call and cache the results if it applies the function after the join).
As with any query optimization question, the first step is always to generate a query plan and see if the different queries actually produce different plans. I would expect the plans to be identical and, thus, the performance to be identical. But there are any number of reasons that one of the two options might produce different plans on your system given your optimizer statistics, initialization parameters, etc.