(495) 925-0049, ITShop интернет-магазин 229-0436, Учебный Центр 925-0049
  Главная страница Карта сайта Контакты
Поиск
Вход
Регистрация
Рассылки сайта
 
 
 
 
 

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

Источник: all-oracle

Рекомендовано для:
  • 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

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


 Распечатать »
 Правила публикации »
  Обсудить материал в конференции Oracle »
Написать редактору 
 Рекомендовать » Дата публикации: 30.07.2012 
 

Магазин программного обеспечения   WWW.ITSHOP.RU
Oracle Database Personal Edition Named User Plus Software Update License & Support
Oracle Database Standard Edition 2 Processor License
Oracle Database Personal Edition Named User Plus License
Oracle Database Standard Edition 2 Named User Plus License
VideoStudio X9 Pro. Электронный ключ.
 
Другие предложения...
 
Курсы обучения   WWW.ITSHOP.RU
 
Другие предложения...
 
Магазин сертификационных экзаменов   WWW.ITSHOP.RU
 
Другие предложения...
 
3D Принтеры | 3D Печать   WWW.ITSHOP.RU
 
Другие предложения...
 
Новости по теме
 
Рассылки Subscribe.ru
Информационные технологии: CASE, RAD, ERP, OLAP
Новости ITShop.ru - ПО, книги, документация, курсы обучения
Программирование на Microsoft Access
CASE-технологии
Компьютерный дизайн - Все графические редакторы
СУБД Oracle "с нуля"
Adobe Photoshop: алхимия дизайна
 
Статьи по теме
 
Новинки каталога Download
 
Исходники
 
Документация
 
Обсуждения в форумах
Пишу программы на заказ для студентов (217)
Пишу для студентов на с, с++, паскаль в средах ms visual studio, qt, builder, borland c, delphi....
 
Access, Ключевое поле, Счетчик (10)
Подскажите пожалуйста, как изменить в Access в ключевом поле (счетчик последовательно),...
 
Ищу программиста для написания программы (46)
Ищу программиста ,владеющего Вижуал Бэйсик и программированием в Экселе, для написания...
 
Написание любых программ на заказ (15)
Напишу любую программу на заказ
 
Написание программ для микроконтроллеров AVR, PIC, ARM, STM32 (14)
Напишу любую программу на любом искусственном языке. Профессиональный программист. Основная...
 
 
 



    
rambler's top100 Rambler's Top100