Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Базы данных / БД2012 / Understanding.SQL.doc
Скачиваний:
283
Добавлен:
28.03.2015
Размер:
1.75 Mб
Скачать

Упорядочение агрегатных групп

ORDER BY может кроме того, использоваться с GROUP BY для упорядочения групп. Если это так, то ORDER BY всегда приходит последним. Вот - пример из последней главы с добавлением предложения ORDER BY. Перед сгруппированием вывода, порядок групп был произвольным; и мы, теперь, заставим группы размещаться в последовательности:

SELECT snum, odate, MAX (amt)

FROM Orders

GROUP BY snum, odate

GROUP BY snum;

Вывод показывается в Рисунке 7.6.

=============== SQL Execution Log ==============

| |

| SELECT snum, odate, MAX (amt) |

| FROM Orders |

| GROUP BY snum, odate |

| ORDER BY snum ; |

| =============================================== |

| snum odate amt |

| ----- ---------- -------- |

| 1001 10/06/1990 767.19 |

| 1001 10/05/1990 4723.00 |

| 1001 10/05/1990 9891.88 |

| 1002 10/06/1990 5160.45 |

| 1002 10/04/1990 75.75 |

| 1002 10/03/1990 1309.95 |

| 1003 10/04/1990 1713.23 |

| 1004 10/03/1990 1900.10 |

| 1007 10/03/1990 1098.16 |

| |

================================================

Рисунок 7. 6: Упорядочение с помощью группы Так как мы не указывали на возрастание или убывание порядка, возрастание используется по умолчанию.

Упорядочение вывода по номеру столбца

Вместо имен столбца, вы можете использовать их порядковые номера для указания поля используемого в упорядочении вывода. Эти номера могут ссылаться не на порядок столбцов в таблице, а на их порядок в выводе. Другими словами, поле упомянутое в предложении SELECT первым, для ORDER BY - это поле 1, независимо от того каким по порядку оно стоит в таблице. Например, вы можете использовать следующую команду чтобы увидеть определенные пол таблицы Продавцов, упорядоченными в порядке убывани к наименьшему значению комиссионных ( вывод показывается Рисунке 7.7 ):

SELECT sname, comm

FROM Salespeople

GROUP BY 2 DESC;

=============== SQL Execution Log ============

| |

| (SELECT sname, comm |

| FROM Salespeople |

| ORDER BY 2 DESC; |

| ============================================= |

| sname comm |

| -------- -------- |

| Peel 0.17 |

| Serres 0.13 |

| Rifkin 0.15 |

| |

===============================================

Рисунок 7. 7: Упорядочение использующее номера Одна из основных целей этой возможности ORDER BY - дать вам возможность использовать GROUP BY со столбцами вывода также как и со столбцами таблицы. Столбцы производимые агрегатной функцией, константы, или выражения в предложении SELECT запроса, абсолютно пригодны для использования с GROUP BY, если они ссылаются к ним с помощью номера. Например, давайте сосчитаем порядки каждого из наших продавцов, и выведем результаты в убывающем порядке, как показано в Рисунке 7.8:

SELECT snum, COUNT ( DISTINCT onum )

FROM Orders

GROUP BY snum

ORDER BY 2 DESC;

=============== SQL Execution Log ==============

| |

| SELECT snum, odate, MAX (amt) |

| FROM Orders |

| GROUP BY snum |

| ORDER BY 2 DESC; |

| =============================================== |

| snum |

| ----- ---------- |

| 1001 3 |

| 1002 3 |

| 1007 2 |

| 1003 1 |

| 1004 1 |

| |

================================================

Рисунок 7.8: Упорядочение с помощью столбца вывода В этом случае, вы должны использовать номер столбца, так как столбец вывода не имеет имени; и вы не должны использовать саму агрегатную функцию. Строго говор по правилам ANSI SQL, следующее не будет работать, хотя некоторые системы и пренебрегают этим требованием:

SELECT snum, COUNT ( DISTINCT onum )

FROM Orders

GROUP BY snum

GROUP BY COUNTОМ ( DISTINCT onum ) DESC;

Это будет отклонено большинством систем!

Соседние файлы в папке БД2012