SELECT *
FROM Orders
ORDER BY cnum DESC;
Вывод показывается в Рисунке 7.4.
SQL Execution Log
SELECT * FROM Orders ORDER BY cnum DESC;
onum
|
amt
|
odate
|
cnum
|
snum
|
3001
|
18.69
|
10/03/1990
|
2008
|
1007
|
3006
|
1098.16
|
10/03/1990
|
2008
|
1007
|
3002
|
1900.10
|
10/03/1990
|
2007
|
1004
|
3008
|
4723.00
|
10/05/1990
|
2006
|
1001
|
3011
|
9891.88
|
10/06/1990
|
2006
|
1001
|
3007
|
75.75
|
10/04/1990
|
2004
|
1002
|
3010
|
1309.95
|
10/06/1990
|
2004
|
1002
|
3005
|
5160.45
|
10/03/1990
|
2003
|
1002
|
3009
|
1713.23
|
10/04/1990
|
2002
|
1003
|
3003
|
767.19
|
10/03/1990
|
2001
|
1001
|
Таблица 7. 4: Упорядочение вывода с помощью убывания поля
УПОРЯДОЧЕНИЕ С ПОМОЩЬЮ МНОГОЧИСЛЕНЫХ СТОЛБЦОВ
Мы можем также упорядочивать таблицу с помощью другого столбца, например с помощью поля amt, внутри упорядочения поля cnum. (вывод показан в Таблице 7.5 ):
SELECT *
FROM Orders
ORDER BY cnum DESC, amt DESC;
SQL Execution Log
SELECT * FROM Orders
ORDER BY cnum DESC, amt DESC;
onum
|
amt
|
odate
|
cnum
|
snum
|
3006
|
1098.16
|
10/03/1990
|
2008
|
1007
|
3001
|
18.69
|
10/03/1990
|
2008
|
1007
|
3002
|
1900.10
|
10/03/1990
|
2007
|
1004
|
3011
|
9891.88
|
10/06/1990
|
2006
|
1001
|
3008
|
4723.00
|
10/05/1990
|
2006
|
1001
|
3010
|
1309.95
|
10/06/1990
|
2004
|
1002
|
3007
|
75.75
|
10/04/1990
|
2004
|
1002
|
3005
|
5160.45
|
10/03/1990
|
2003
|
1002
|
3009
|
1713.23
|
10/04/1990
|
2002
|
1003
|
3003
|
767.19
|
10/03/1990
|
2001
|
1001
|
Таблица 7.5: Упорядочение вывода с помощью многочисленых полей
Вы можете использовать ORDER BY таким же способом сразу с любым числом столбцов. Обратите внимание что, во всех случаях, столбцы которые упорядочиваются должны быть указаны в выборе SELECT. Это - требование ANSI которые в большинстве, но не всегда, предписано системе. Следующая команда, например, будет запрещена:
SELECT cname, city
FROM Customers
GROUP BY cnum;
Так как поле cnum не было выбранным полем, GROUP BY не cможет найти его чтобы использовать для упорядочения вывода. Даже если ваша система позволяет это, смысл упорядочения не будет понятен из вывода, так что включение (в предложение SELECT) всех столбцов, используемых в предложении ORDER BY, в принципе желательно.
УПОРЯДОЧЕНИЕ АГРЕГАТНЫХ ГРУПП
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 ):
Читать дальше