что значит order by в sql

Сортировка данных в SQL (ORDER BY)

При выборке данных бывает важно получить их в определенном упорядоченном виде. Сортировка может быть выполнена по любым полям с любым типом данных. Это может быть сортировка по возрастанию или убыванию для числовых полей. Для символьных (текстовых) полей это может быть сортировка в алфавитном порядке, хотя по сути, она так же является сортировкой по возрастанию или убыванию. Она так же может быть выполнена в любых направлениях – от А, до Я, и наоборот от Я, до А.

Суть процесса сортировки заключается к приведению последовательности к определенному порядку. Подробней о сортировки можно узнать в статье «Алгоритмы сортировки». Например, сортировка произвольной числовой последовательности по возрастанию:

должна привести к упорядоченной последовательности:

Аналогично, при сортировке по возрастанию строковых значений:

Иванов Иван, Петров Петр, Иванов Андрей

результат должен быть:

Иванов Андрей, Иванов Иван, Петров Петр

Здесь строка «Иванов Андрей» перешла в начало, так как сравнение строк производится посимвольно. Обе строки начинаются одинаковых символов «Иванов «. Так как символ «А» в слове «Андрей» идет раньше в алфавите, чем символ «И» в слове «Иван», то эта строка будет поставлена раньше.

Сортировка в запросе SQL

Для выполнения сортировки в строку запроса нужно добавить команду ORDER BY. После этой команды указывается поле, по которому производится сортировка.

Для примеров используем таблицу товаров goods:

num
(номер товара)
title
(название)
price
(цена)
1 Мандарин 50
2 Арбуз 120
3 Ананас 80
4 Банан 40

Данные здесь уже упорядочены по столбцу «num». Теперь, построим запрос, который выведет таблицу с товарами, упорядоченными в алфавитном порядке:

SELECT * FROM goods – указывает выбрать все поля из таблицы goods;

ORDER BY – команда сортировки;

title – столбец, по которому будет выполняться сортировка.

Результат выполнения такого запроса следующий:

num title price
3 Ананас 80
2 Арбуз 120
4 Банан 40
1 Мандарин 50

Так же можно выполнить сортировку для любого из полей таблицы.

Направление сортировки

По умолчанию, команда ORDER BY выполняет сортировку по возрастанию. Чтобы управлять направлением сортировки вручную, после имени столбца указывается ключевое слово ASC (по возрастанию) или DESC (по убыванию). Таким образом, чтобы вывести нашу таблицу в порядке убывания цен, нужно задать запрос так:

Сортировка по возрастанию цены будет:

Сортировка по нескольким полям

SQL допускает сортировку сразу по нескольким полям. Для этого после команды ORDER BY необходимые поля указываются через запятую. Порядок в результате запроса будет настраиваться в той же очередности, в которой указаны поля сортировки.

column1 column2 column3
3 1 c
1 3 c
2 2 b
2 1 b
1 2 a
1 3 a
3 4 a

Отсортируем таблицу по следующим правилам:

Т.е. первый столбец по возрастанию, второй по убыванию, третий опять по возрастанию. Запрос упорядочит строки по первому столбцу, затем, не разрушая первого правила, по второму столбцу. Затем, так же, не нарушая имеющихся правил, по третьему. В результате получится такой набор данных:

column1 column2 column3
1 3 a
1 3 c
1 2 a
2 2 b
2 1 b
3 1 a
3 1 c

Порядок команды ORDER BY в запросе

Сортировка строк чаще всего проводится вместе с условием на выборку данных. Команда ORDER BY ставится после условия выборки WHERE. Например, выбираем товары с ценой меньше 100 рублей, упорядочив по названию в алфавитном порядке:

Источник

SQL ORDER BY: Полное руководство

Оператор SQL ORDER BY определяет порядок, в котором записи возвращаются запросом. Вы можете возвращать записи в возрастающем или убывающем порядке по значению любого столбца в таблице.

Упорядочивание результатов запроса упрощает поиск нужных записей.

Например, предположим, что вы хотите знать, какие сотрудники получили награды за наибольшее количество сотрудников месяца. Вы можете упорядочить свой запрос по этой точке данных, чтобы отобразить сотрудника, который первым получил наибольшее количество наград.

Оператор SQL ORDER BY упорядочивает результаты запроса в зависимости от ваших условий. В этом руководстве мы собираемся обсудить, как использовать оператор ORDER BY. Мы рассмотрим пример, который поможет вам освоить это ключевое слово.

SQL ORDER BY

Ключевое слово SQL ORDER BY упорядочивает результаты запроса. Вы можете упорядочить результаты в возрастающем или убывающем порядке по определённому столбцу или набору столбцов.

Вот синтаксис запроса ORDER BY:

SELECT name
FROM employees
ORDER BY name, joined ASC;

После оператора SQL SELECT мы указываем имя столбца, который хотим получить. Затем мы заявляем, что хотим получить данные из таблицы сотрудников.

Оператор ORDER BY упорядочивает наш запрос по имени и объединённым столбцам в порядке убывания. Наша база данных сначала будет отсортирована по именам в порядке убывания.

Если есть несколько человек с одинаковыми именами, то человек, который присоединился последним, появится внизу этих имён.

По умолчанию SQL упорядочивает столбец в порядке возрастания. Вы можете заказать столбец в порядке убывания или убывания с помощью предложения SQL ORDER BY.

Два возможных порядка сортировки:

Вы можете использовать список столбцов, чтобы упорядочить несколько столбцов в разном порядке:

SELECT name
FROM employees
ORDER BY name ASC, joined DESC;

Этот запрос упорядочивает нашу таблицу по имени в возрастающем порядке. Тогда наш стол заказана вступил в порядке убывания.

Читайте также:  школьная форма хорошего качества рейтинг

Пример ORDER BY SQL

Давайте запустим пример запроса, чтобы продемонстрировать оператор ORDER BY в действии. Мы хотим получить список всех имён сотрудников и титулов для каждого сотрудника. Наша цель — отсортировать этот список в алфавитном порядке по именам сотрудников.

Чтобы получить эти данные, мы могли бы использовать следующий запрос:

SELECT name, title FROM employees ORDER BY name ASC;

Наш запрос сортирует набор результатов. Вот наш набор результатов в порядке возрастания:

имя заглавие
Алексис Сотрудник по продажам
Джефф Старший специалист по продажам
Ханна Сотрудник по продажам
Иона Вице-президент по продажам
Люк Сотрудник по продажам
Майк Сотрудник по продажам

Если вы хотите отсортировать в обратном алфавитном порядке, вы должны заменить оператор ASC на DESC.

Вы также можете сортировать по нескольким столбцам. Это может быть полезно, если в вашей таблице есть повторяющиеся значения, которые вы хотите отсортировать.

Например, предположим, что вы хотите узнать, кто работал на вас наиболее короткое время, в порядке их названий. Вы можете сделать это, используя следующий запрос:

SELECT name, title, hired_date FROM employees ORDER BY title, hired_date DESC;

Наш оператор ORDER BY сортирует результаты запроса. Вот результат нашего запроса:

имя заглавие hired_date
Эмма Директор по маркетингу 2010-03-19
Алексис Сотрудник по продажам 2014-04-01
Ханна Сотрудник по продажам 2011-09-30
Майк Сотрудник по продажам 2010-03-19
Люк Сотрудник по продажам 2009-12-03
Джефф Старший специалист по продажам 2012-03-17
Иона Вице-президент по продажам 2010-07-23

Как видите, наша таблица отсортирована как по должности сотрудника, так и по дате его приёма на работу. Наш оператор ORDER BY успешно отсортировал записи.

Самым недавно нанятым торговым представителем был Алексис. Нашим торговым партнёром, который дольше всех работает в компании, является Люк. Мы также можем увидеть дату приёма на работу всех остальных сотрудников в порядке их должностей.

Вывод

Оператор SQL ORDER BY изменяет порядок, в котором записи возвращаются запросом. Вы можете заказать запрос в возрастающем или убывающем порядке. По умолчанию запрос возвращает данные в порядке возрастания.

Хотите узнать больше о SQL? Прочтите наше руководство по изучению SQL. Вы найдёте лучшие советы по изучению SQL. В нашем руководстве мы подготовили список учебных ресурсов, которые помогут вам развить необходимые навыки. навыки.

Источник

SELECT — предложение ORDER BY (Transact-SQL)

Сортирует данные, возвращенные запросом в SQL Server. Это предложение используется для следующих целей:

Упорядочение результирующего набора запроса по заданному списку столбцов и (дополнительно) ограничение числа возвращаемых строк указанным диапазоном. Порядок, в котором строки возвращаются в результирующем наборе, не гарантируется, если не указано предложение ORDER BY.

Определение порядка, в котором значения ранжирующей функции применяются к результирующему набору.

Синтаксические обозначения в Transact-SQL

ORDER BY не поддерживается в инструкциях SELECT/INTO или CREATE TABLE AS SELECT (CTAS) в Azure Synapse Analytics или Система платформы аналитики (PDW).

Синтаксис

Ссылки на описание синтаксиса Transact-SQL для SQL Server 2014 и более ранних версий, см. в статье Документация по предыдущим версиям.

Аргументы

order_by_expression
Указывает столбец или выражение, по которому производится сортировка результирующего набора запроса. Столбец сортировки может быть указан с помощью имени или псевдонима столбца или неотрицательного целого числа, представляющего позицию столбца в списке выбора.

Можно указать несколько столбцов сортировки. Имена столбцов должны быть уникальными. Последовательность столбцов сортировки в предложении ORDER BY определяет организацию упорядоченного результирующего набора. Иными словами, результирующий набор сортируется по первому столбцу, затем упорядоченный список сортируется по второму и т. д.

Имена столбцов, на которые содержатся ссылки в предложении ORDER BY, должны однозначно соответствовать столбцу или псевдониму столбца в списке выбора либо столбцу, определенному в таблице, указанной в предложении FROM. Если предложение ORDER BY ссылается на псевдоним столбца в списке выбора, псевдоним должен использоваться отдельно, а не как часть выражения в предложении ORDER BY, например:

COLLATE collation_name
Указывает, что операция ORDER BY должна выполняться в соответствии с параметрами сортировки, указанными в аргументе collation_name, но не в соответствии с параметрами сортировки столбца, определенными в таблице или представлении. Аргументом collation_name может быть либо имя параметров сортировки Windows, либо имя параметров сортировки SQL. Дополнительные сведения см. в статье Collation and Unicode Support. Аргумент COLLATE применяется только к столбцам типа char, varchar, nchar и nvarchar.

ASC | DESC
Указывает порядок сортировки значений в указанном столбце — по возрастанию или по убыванию. Значение ASC сортирует от низких значений к высоким. Значение DESC сортирует от высоких значений к низким. Порядок сортировки по умолчанию — ASC. Значения NULL рассматриваются как минимально возможные значения.

OFFSET < integer_constant | offset_row_count_expression > < ROW | ROWS >
Указывает число сток, которые необходимо пропустить, прежде чем будет начат возврат строк из выражения запроса. Это значение может быть целочисленной константой или выражением, значение которого больше нуля или равно нулю.

Читайте также:  я твой супергерой ты хорошая песня

Применимо к: SQL Server 2012 (11.x) и выше, База данных SQL Azure.

offset_row_count_expression может быть переменной, параметром или вложенным запросом, возвращающим скалярную константу. При использовании вложенного запроса он не должен ссылаться на какие-либо столбцы, определенные в области внешнего запроса. Иными словами, он не может коррелировать с внешним запросом.

ROW и ROWS являются синонимами и оставлены для совместимости со стандартом ANSI.

В плане выполнения запроса значение смещения строки отображается в атрибуте Offset оператора запроса TOP.

FETCH < FIRST | NEXT >< integer_constant | fetch_row_count_expression > < ROW | ROWS >ONLY
Указывает число строк, возвращаемых после обработки предложения OFFSET. Это значение может быть целочисленной константой или выражением, значение которого больше единицы или равно единице.

Применимо к: SQL Server 2012 (11.x) и выше, а также База данных SQL Azure.

fetch_row_count_expression может быть переменной, параметром или вложенным запросом, возвращающим скалярную константу. При использовании вложенного запроса он не должен ссылаться на какие-либо столбцы, определенные в области внешнего запроса. Иными словами, он не может коррелировать с внешним запросом.

FIRST и NEXT являются синонимами и предусмотрены для совместимости со стандартом ANSI.

ROW и ROWS являются синонимами и оставлены для совместимости со стандартом ANSI.

В плане выполнения запроса значение смещения строки отображается в атрибуте Rows или Top оператора запроса TOP.

Рекомендации

Избегайте указания столбцов в предложении ORDER BY по их порядковому номеру в списке выбора. Например, хотя инструкция SELECT ProductID, Name FROM Production.Production ORDER BY 2 верна, она будет не очень понятна другим пользователям по сравнению с тем случаем, когда столбцы указаны по именам. Кроме того, если список выбора изменится, в частности изменится порядок столбца или будут добавлены новые столбцы, то это потребует изменения предложения ORDER BY во избежание непредвиденных результатов.

В инструкции SELECT TOP (N) всегда указывайте предложение ORDER BY. Это единственный способ предсказуемым образом отметить строки, которые были обработаны предложением TOP. Дополнительные сведения см. в разделе TOP (Transact-SQL).

Совместимость

При использовании в инструкции SELECT. INTO или INSERT. SELECT предложения ORDER BY для вставки строк из другого источника вставка строк в указанном порядке не гарантируется.

Использование OFFSET и FETCH в представлении не приведет к изменению его свойства Updateability.

Ограничения

Нет ограничения на число столбцов в предложении ORDER BY, однако общий размер столбцов, перечисленных в нем, не может превышать 8060 байт.

Столбцы типа ntext, text, image, geography, geometry и xml не могут использоваться в предложении ORDER BY.

Нельзя указывать целое число или константу, если аргумент order_by_expression присутствует в ранжирующей функции. Дополнительные сведения см. в статье Предложение OVER (Transact-SQL).

Если в качестве имени таблицы в предложении FROM используется псевдоним, то только псевдоним может быть использован для обозначения столбца этой таблицы в предложении ORDER BY.

Имена и псевдонимы столбцов, указанные в предложении ORDER BY, должны быть определены в списке выбора, если инструкция SELECT содержит одно из следующих предложений или операторов:

Кроме того, если в инструкцию входит оператор UNION, EXCEPT или INTERSECT, то имена и псевдонимы столбцов должны быть указаны в списке выбора первого (слева) запроса.

В запросе, содержащем оператор UNION, EXCEPT или INTERSECT, предложение ORDER BY допускается только в конце инструкции. Это ограничение применяется только при использовании операторов UNION, EXCEPT и INTERSECT в запросах верхнего уровня, но не во вложенных запросах. См подраздел «Примеры» ниже.

Предложение ORDER BY недопустимо в представлениях, встроенных функциях, производных таблицах и вложенных запросах, если также не указаны предложения TOP либо OFFSET и FETCH. В этих объектах предложение ORDER BY используется только для определения строк, возвращаемых предложением TOP или OFFSET и FETCH. Предложение ORDER BY не гарантирует упорядочивания результатов при запросе этих конструкций, если оно не указано в самом запросе.

Предложения OFFSET и FETCH не поддерживаются в индексированных представлениях и представлениях, определенных с предложением CHECK OPTION.

Предложения OFFSET и FETCH могут быть использованы в любом запросе, допускающем применение TOP и ORDER BY, со следующими ограничениями.

Предложение OVER не поддерживает OFFSET и FETCH.

Предложения OFFSET и FETCH не могут быть указаны прямо в инструкциях INSERT, UPDATE, MERGE и DELETE, но могут быть указаны во вложенных запросах, определяемых этими инструкциями. Например, в инструкции INSERT INTO SELECT предложения OFFSET и FETCH могут быть указаны в инструкции SELECT.

В запросе, содержащем оператор UNION, EXCEPT или INTERSECT, предложения OFFSET и FETCH могут быть указаны только в конечном запросе, который определяет порядок следования результатов запроса.

TOP нельзя сочетать с OFFSET и FETCH в одном выражении запроса (в той же области запроса).

Использование OFFSET и FETCH для ограничения числа возвращаемых строк

Для разбиения на страницы и ограничения числа строк, передаваемых клиентскому приложению, рекомендуется пользоваться предложениями OFFSET и FETCH, а не предложением TOP.

Читайте также:  Что лучше для обезжиривания поверхности металла

Применение в качестве решения для разбиения на страницы предложений OFFSET и FETCH потребует однократного выполнения запроса для каждой «страницы» данных, возвращаемых клиентскому приложению. Например, чтобы вернуть результаты запроса блоками по 10 строк, необходимо выполнить запрос для получения строк с 1 по 10, затем еще раз для получения строк с 11 по 20 и так далее. Каждый запрос выполняется независимо и никаким образом не связан с другими запросами. Это означает, что в отличие от использования курсора, где запрос выполняется всего один раз, а текущее состояние хранится на сервере, за отслеживание состояния отвечает клиентское приложение. Чтобы добиться стабильных результатов между запросами с предложениями OFFSET и FETCH, должны выполняться следующие условия.

Базовые данные, используемые запросом, должны быть неизменными. Иными словами, либо строки, обработанные запросом, не должны обновляться, либо все запросы страниц выполняемого запроса должны выполняться в одной транзакции, использующей моментальный снимок или сериализуемую изоляцию транзакции. Дополнительные сведения об уровнях изоляции транзакции см. в разделе SET TRANSACTION ISOLATION LEVEL (Transact-SQL).

Предложение ORDER BY содержит столбец или сочетание столбцов, которые гарантированно уникальны.

См. пример «Выполнение нескольких запросов в одной транзакции» в подразделе «Примеры» ниже в этом разделе.

Если согласованность планов выполнения важна для решения разбиения на страницы, подумайте над использованием указания запросов OPTIMIZE FOR для параметров OFFSET и FETCH. См. пункт «Указание выражений для значений OFFSET и FETCH» в подразделе «Примеры» ниже в этом разделе. Дополнительные сведения об OPTIMZE FOR см. в статье Указания запросов (Transact-SQL).

Примеры

Категория Используемые элементы синтаксиса
Основной синтаксис ORDER BY
Указание порядка по возрастанию или по убыванию DESC • ASC
Указание параметров сортировки COLLATE
Указание условного порядка CASE, выражение
Использование ORDER BY в ранжирующей функции Ранжирующие функции
Ограничение числа возвращаемых строк OFFSET • FETCH
Использование ORDER BY с UNION, EXCEPT и INTERSECT UNION

Основной синтаксис

В примерах этого раздела показана базовая функциональность предложения ORDER BY с использованием минимально необходимого синтаксиса.

A. Указание единственного столбца, определенного в списке выбора

Б. Указание столбца, не определенного в списке выбора

В следующем примере результирующий набор упорядочивается по столбцу, не включенному в список выбора, но определенному в таблице, указанной в предложении FROM.

В. Указание псевдонима в качестве столбца сортировки

Г. Указание выражения в качестве столбца сортировки

В следующем примере в качестве столбца сортировки используется выражение. Выражение определено с использованием функции DATEPART, чтобы сортировать результирующий набор по году поступления сотрудника на работу.

Указание порядка по возрастанию или по убыванию

A. Указание порядка по убыванию

В следующем примере производится упорядочение результирующего набора по числовому столбцу ProductID в убывающем порядке.

Б. Указание порядка по возрастанию

В следующем примере производится упорядочение результирующего набора по столбцу Name в возрастающем порядке. Символьные значения сортируются в алфавитном порядке, а не в числовом. Иными словами, отсортированное значение 10 находится перед 2.

В. Указание порядка и по возрастанию, и по убыванию

Указание параметров сортировки

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

Указание условного порядка

Использование ORDER BY в ранжирующей функции

В следующем примере предложение ORDER BY используется в ранжирующих функциях ROW_NUMBER, RANK, DENSE_RANK и NTILE.

Ограничение числа возвращаемых строк

В следующих примерах предложения OFFSET и FETCH ограничивают число строк, возвращаемых запросом.

Применимо к: SQL Server 2012 (11.x) и выше, а также База данных SQL Azure.

A. Указание целочисленных констант в качестве значений OFFSET и FETCH

Б. Указание переменных в качестве значений OFFSET и FETCH

В. Указание выражений в качестве значений OFFSET и FETCH

Г. Указание вложенного запроса, возвращающего скалярную константу, в качестве значений OFFSET и FETCH

Д. Выполнение нескольких запросов в одной транзакции

В следующем примере показан один из методов реализации решения разбиения на страницы, который обеспечивает стабильные результаты, возвращаемые во всех запросах. Этот запрос выполняется в одной транзакции уровня изоляции моментального снимка, а столбец, указанный в предложении ORDER BY, гарантирует уникальность столбца.

Использование ORDER BY с UNION, EXCEPT и INTERSECT

Примеры: Azure Synapse Analytics и Система платформы аналитики (PDW)

В следующем примере демонстрируется упорядочение результирующего набора по числовому столбцу EmployeeKey в возрастающем порядке.

В следующем примере производится упорядочение результирующего набора по числовому столбцу EmployeeKey в убывающем порядке.

Источник

Библиотека с советами