+7 (495) 229-0436   shopadmin@itshop.ru 119334, г. Москва, ул. Бардина, д. 4, корп. 3
 
 
Вход
 
 
Каталог
 
 
Подписка на новости
Новости ITShop
Windows 7 и Office: Новости и советы
Обучение и сертификация Microsoft
Вопросы и ответы по MSSQLServer
Delphi - проблемы и решения
Adobe Photoshop: алхимия дизайна
 
Ваш отзыв
Оцените качество магазина ITShop.ru на Яндекс.Маркете. Если вам нравится наш магазин - скажите об этом Google!
 
 
Способы оплаты
 
Курс расчета
 
 1 у.е. = 92.51 руб.
 
 Цены показывать:
 
 
 
 
  
Новости, статьи, акции
 

Как читать план исполнения запроса SQL в Oracle

30.07.2012 17:28

Рекомендовано для:
  • Oracle Database 9i R1
  • Oracle Database 9i R2
  • Oracle Database 10g R1
  • Oracle Database 10g R2
  • Oracle Database 11g R1
  • Oracle Database 11g R2

Исполнение любого SQL предложения в Oracle извлекает так называемый "план исполнения". Этот план исполнения запроса является описанием того, как Oracle будет осуществялть выборку данных, согласно исполняемому SQL предложению. План представляет собой дерево, которое содержит порядок шагов и связь между ними.

Базовые правила плана исполнения:

  1. План исполнения имеет корень, ветвь не имеющую родителя
  2. Родительские ветки могут иметь одного и более потомков, и их идентификатор меньше чем идентификатор потомка
  3. У потомка может быть только один родитель, это справедливо и для нескольких уровней вложенности

Приведем пример плана исполнения:

SQL> EXPLAIN PLAN FOR
   2 SELECT E.EMPNO, 
   3        E.ENAME,
   4        D.DNAME
   5 FROM EMP E, 
   6      DEPT D
   7 WHERE E.DEPTNO = D.DEPTNO 
   8       AND E.DEPTNO = 10;
Explained.

SQL> SELECT * FROM TABLE(dbms_xplan.display(null,null,'basic'));

PLAN_TABLE_OUTPUT
------------------------------------------------
Plan hash value: 568005898
------------------------------------------------
/ Id  / Operation                    / Name    /
------------------------------------------------
/   0 / SELECT STATEMENT             /         /
/   1 /  NESTED LOOPS                /         /
/   2 /   TABLE ACCESS BY INDEX ROWID/ DEPT    /
/   3 /    INDEX UNIQUE SCAN         / PK_DEPT /
/   4 /   TABLE ACCESS FULL          / EMP     /
------------------------------------------------

Если следовать перечисленным выше правилам, то:

  • Операция 0 - корень дерева, и у нее один потомок, операция 1
  • У операции 1 два потомка - операции 2 и 4
  • У операции 2 один потомок - операция 3

Если представить это графически, то получиться примерно так:

 

Дерево плана исполнения

 

Если прочитать это дерево, то получим следующее, в порядке выполнения: Для выполнения операции 1, необходимо выполнить операции 2 и 4. Операция 2 выполняется первой. Во время выполнения операции 2, необходимо выполнить операцию 3. Для выполнения операции 4, необходимо выполнить операцию 2.

  • Операция 3 получает доступ к таблице DEPT, используя INDEX UNIQUE SCAN и предоставляет ROWID операции 2
  • Операция 2 возвращает все строки из таблицы DEPT для операции 1
  • Операция 1 выполняет операцию 4, для каждой строки, которую вернула операция 2
  • Операция 4 выполняет полностью просматривает таблицу (TABLE ACCESS FULL) и применяет фильтр E.DEPNO=10 и возвращает строки для операции 1
  • Операция 1 возвращает финальный результат в операцию 0

Ссылки по теме

  
Помощь
Задать вопрос
 программы
 обучение
 экзамены
 компьютеры
Бесплатный звонок
ICQ-консультанты
Skype-консультанты

Общая справка
Как оформить заказ
Тарифы доставки
Способы оплаты
Прайс-лист
Карта сайта
 
Бестселлеры
Курсы обучения "Atlassian JIRA - система управления проектами и задачами на предприятии"
Microsoft Windows 10 Профессиональная 32-bit/64-bit. Все языки. Электронный ключ
Microsoft Office для Дома и Учебы 2019. Все языки. Электронный ключ
Курс "Oracle. Программирование на SQL и PL/SQL"
Курс "Основы TOGAF® 9"
Microsoft Office 365 Персональный 32-bit/x64. 1 ПК/MAC + 1 Планшет + 1 Телефон. Все языки. Подписка на 1 год. Электронный ключ
Курс "Нотация BPMN 2.0. Ее использование для моделирования бизнес-процессов и их регламентации"
 

О нас
Интернет-магазин ITShop.ru предлагает широкий спектр услуг информационных технологий и ПО.

На протяжении многих лет интернет-магазин предлагает товары и услуги, ориентированные на бизнес-пользователей и специалистов по информационным технологиям.

Хорошие отзывы постоянных клиентов и высокий уровень специалистов позволяет получить наивысший результат при совместной работе.

В нашем магазине вы можете приобрести лицензионное ПО выбрав необходимое из широкого спектра и ассортимента по самым доступным ценам. Наши менеджеры любезно помогут определиться с выбором ПО, которое необходимо именно вам. Также мы проводим учебные курсы. Мы приглашаем к сотрудничеству учебные центры, организаторов семинаров и бизнес-тренингов, преподавателей. Сфера сотрудничества - продвижение бизнес-тренингов и курсов обучения по информационным технологиям.



 

О нас

 
Главная
Каталог
Новинки
Акции
Вакансии
 

Помощь

 
Общая справка
Как оформить заказ
Тарифы доставки
Способы оплаты
Прайс-лист
Карта сайта
 

Способы оплаты

 

Проекты Interface Ltd.

 
Interface.ru   ITShop.ru   Interface.ru/training   Olap.ru   ITnews.ru  
 

119334, г. Москва, ул. Бардина, д. 4, корп. 3
+7 (495) 229-0436   shopadmin@itshop.ru
Проверить аттестат
© ООО "Interface Ltd."
Продаем программное обеспечение с 1990 года