Отговор на вашия въпрос - Да, Редът на таблицата има значение при присъединяването.
Можете също така да уведомите оптимизатора за плана за изпълнение.
Подсказката ORDERED кара Oracle да обедини таблиците в реда, в който се появяват в клаузата FROM.
Например, този израз свързва таблица TAB1 с таблица TAB2 и след това свързва резултата с таблица TAB3:
SELECT /*+ ORDERED */ TAB1.COL1, TAB2.COL2, TAB3.COL3
FROM TAB1, TAB2, TAB3
WHERE TAB1.COL1 = TAB2.COL1
AND TAB2.COL1 = TAB3.COL1;
Ако пропуснете подсказката ORDERED от SQL израз, изпълняващ обединяване, оптимизаторът избира реда, в който да обедини таблиците. Може да искате да използвате подсказката ORDERED, за да посочите ред на присъединяване, ако знаете нещо за броя на избраните редове от всяка таблица, което оптимизаторът не знае. Такава информация ще ви позволи да изберете вътрешна и външна таблица по-добре, отколкото оптимизаторът би могъл.
Обикновено, ако анализирате таблиците, оптимизаторът избира ефективен звезден план. Можете също да използвате съвети, за да подобрите плана. Най-прецизният метод е да подредите таблиците в клаузата FROM по реда на ключовете в индекса, като голямата таблица е последна. След това използвайте следните съвети:
/*+ ORDERED USE_NL(FACTS) INDEX(FACTS FACT_CONCAT) */