Firebird РУКОВОДСТВО РАЗРАБОТЧИКА БАЗ ДАННЫХ - Хелен Борри
Шрифт:
Интервал:
Закладка:
Firebird 1.5 поддерживает размещение значений NULL, если присутствуют, в элементе сортировки. Значение по умолчанию, NULLS LAST, означает, что строки NULL будут помещены в конец списка. Задавайте NULLS FIRST для размещения NULL перед всеми другими значениями.
Когда присутствует несколько элементов сортировки, то горизонтальный порядок элементов в предложении является значимым - сортировка выполняется слева направо.
СтолбцыЭлементами сортировки обычно являются столбцы. Индексированные столбцы сортируются много быстрее, чем неиндексированные. Если сортировка использует множество столбцов в непрерывной последовательности слева направо, то составной индекс, созданный из таких сортируемых элементов в той же последовательности слева направо с соответствующим направлением сортировки (ASC/DESC), может резко повысить скорость сортировки.
В запросах UNION и GROUP BY столбец, используемый для сортировки, должен присутствовать в выходном списке. В других запросах невыводимые столбцы и (в версии 1.5) выражения, содержащие невыводимые столбцы, допустимы для критерия упорядочения.
Оператор в примере 23.1 показывает сортировку по столбцам в простейшей форме.
Пример 23.1. Простейшая сортировка по столбцам
SELECT COLA, COLB, COLC, COLD
FROM TABLEA
ORDER BY COLA, COLD;
Использование алиасов таблицПри спецификации упорядоченного набора, который использует соединение или коррелированные подзапросы, вы должны указывать полные идентификаторы для всех элементов сортировки, являющихся столбцами базы данных, или обращаться к столбцам базы данных, используя идентификаторы таблиц или алиасы, которые были заданы в предложениях FROM и JOIN, как показано в примере 23.2.
Пример 23.2, Алиасы таблиц в предложении упорядочения
SELECT A.COLA, A.COLB, B.COL2, B.C0L3
FROM TABLEA А
JOIN TABLEB В ON A.COLA = B.COL1
WHERE A.COLX = 'Sold'
ORDER BY A.COLA, B.COL3;
ВыраженияВ Firebird 1.5 и выше правильные выражения допустимы в качестве элементов сортировки, даже если выражение не выводится в виде выходного столбца. Вы можете сортировать наборы по выражениям внутренних и внешних функций или скалярным значениям коррелированных подзапросов (пример 23.3). Если столбец выражения, по которому вы хотите выполнять сортировку, присутствует в выходном списке, вы не можете использовать его имя алиаса в качестве элемента упорядочения. или повторите выражение в предложении ORDER BY, или используйте порядковый номер столбца (см. разд. "Порядковые номера").
Пример 23.3. Упорядочение по полю выражения
SELECT EMP_NO || '-' || SUBSTRING (LAST_NAME FROM 1 FOR 3) AS NAMECODE
FROM EMPLOYEE
ORDER BY EMP_NO || '-' || SUBSTRING (LAST_NAME FROM 1 FOR 3);
Альтернативный способ - замена выражения в предложении упорядочения на порядковый номер поля выражения:
SELECT EMP_NO || '-' || SUBSTRING (LAST_NAME FROM 1 FOR 3) AS NAMECODE
FROM EMPLOYEE
ORDER BY 1;
Если вам нужна сортировка по выражению в версии 1.0.x, необходимо включить выражение в выходной список и использовать его порядковый номер в предложении
ORDER BY.
Сортировка по выражениям процедур или функцийСортировка по значениям, возвращаемым обычными или внешними функциями или хранимыми процедурами, похожа на другие виды сортировки: она будет выполняться в соответствии с обычными правилами для типов данных возвращаемых значений. Вы ответственны за указание сортировки только по значениям, которые соответствуют некоторой логической последовательности. В качестве примера неправильной последовательности рассмотрим следующее:
. . .
ORDER BY CAST (SALES_DATE AS VARCHAR(24))
Строки будут упорядочены в алфавитно-цифровой последовательности символов без соответствия датам, с которыми оперирует это выражение.
! ! !
ВНИМАНИЕ! При использовании выражений в качестве критериев упорядочения помните о значительном расходовании ресурсов на сервере при дублировании вычисления выражения для каждой найденной строки. Влияние этого будет в лучшем случае непредсказуемым. Умеренно используйте в этом типе операции количество наборов.
. ! .
Порядковые номераОсобый вид выражения, который может быть задан в качестве критерия сортировки, является порядковым номером в списке выходных столбцов. Порядковый номер является позицией столбца в выходном списке, подсчитываемой слева направо, начиная с единицы. В примере 23.4 снова используется простой запрос из примера 23.1, где используются порядковые номера вместо идентификаторов столбцов.
Пример 23.4. Подстановка порядковых номеров вместо имен столбцов
SELECT COLA, COLB, COLC, COLD
FROM TABLEA
ORDER BY 1, 4;
Предложение упорядочения для сортировки выхода запроса объединения (union) может использовать только порядковые номера для ссылки на столбцы упорядочивания, как показано в примере 23.5.
Пример 23.5. Упорядочивание наборов UNION
SELECT
T.FIRST_NAME, T.LAST_NAME, 'YES' AS "TEAM LEADER?"
FROM EMPLOYEE T
WHERE EXISTS(SELECT 1 FROM PROJECT P1
WHERE PI.TEAM_LEADER = T.EMP_NO)
UNION
SELECT
E.FIRST_NAME, E.LAST_NAME, 'NO ' AS "TEAM LEADER?"
FROM EMPLOYEE E
WHERE NOT EXISTS(SELECT 1 FROM PROJECT P2
WHERE P2 .TEAM_LEADER = E.EMP_NO)
ORDER BY 2, 1;
В версии 1.0.x упорядочивание по порядковым номерам является единственным способом использования выражений в качестве критерия сортировки, а столбцы, полученные из выражений, должны быть представлены в спецификации вывода (см. пример 23.6). В версии 1.5 у вас есть вариант использования выражения в качестве элемента сортировки без включения элемента выражения в выходной набор, как показано в примере 23.7.
Пример 23.6. Любая версия
SELECT
FULL_NAME, STRLEN (FULL_NAME)
FROM EMPLOYEE
ORDER BY 2 DESC;
Пример 23 7 Firebird 1 5 и выше
SELECT FULL_NAME FROM EMPLOYEE
ORDER BY STRLEN(FULL_NAME) DESC;
Использование порядкового номера полезно для сохранения контроля типов данных и устранения помех, когда выходной набор включает соединения, поскольку все столбцы базы данных, объявленные как критерий упорядочения, должны иметь полностью определенные идентификаторы.
Сортировка по порядковому номеру не увеличивает скорость выполнения запроса; сервер заново вычисляет выражения для операции сортировки.
Направление сортировки
По умолчанию сортировка выполняется в возрастающем порядке. Для выполнения сортировки в убывающем порядке добавьте ключевое слово DESC, как показано в примере 23.8. Если вам нужна убывающая сортировка, создайте для нее убывающий индекс. Firebird не может "инвертировать" возрастающий индекс и использовать его для убывающей сортировки, так же как он не может использовать убывающий индекс для возрастающей сортировки.
Пример 23.8. Убывающий порядок сортировки
SELECT FIRST LU * FROM DOCUMENT
ORDER BY STRLEN(DESCRIPTION) DESC
Размещение пустых значений
По умолчанию Firebird помещает сортируемые столбцы, имеющие NULL, В конец выходного набора. Начиная с версии 1.5, вы можете использовать ключевое слово NULLS FIRST для указания того, что строки с NULL будут помещаться в начало набора, как показано в примере 23.9.
! ! !
ПРИМЕЧАНИЕ. Никакой индекс не может быть использован для сортируемого элемента, если указано NULLS FIRST.
. ! .
Пример 23.9. Размещение пустого значения
SELECT * FROM EMPLOYEE
ORDER BY PHONE_EXT NULLS FIRST
Предложение GROUP BY
Когда запрос включает предложение GROUP BY, TO спецификация столбца и таблицы, а именно:
SELECT {<список-столбцов>}
FROM <спецификация-таблицы>
[WHERE <условие-поиска>]
передается следующей стадии обработки, где строки разделяются на одну или более вложенных групп.
Обычно каждая часть создает некоторый итог, используя выражения, которые выполняют некоторые операции над группой числовых значений. Такой тип запроса называется группирующим запросом, а его результат часто называется сгруппированным набором.
Его синтаксис:
SELECT <список-группируемых-полей> FROM <спецификация-таблицы>
[WHERE...]
GROUP BY <группирующий-элемент> [COLLATE последовательность-сортировки]
[, <группирующий-элемент> [. . ] ]
HAVING <предикат-группируемых-столбцов>
[ORDER BY .. .] ;
Список группируемых полей
Группа формируется путем объединения (агрегирования) всех строк, где столбец, указанный в списке столбцов и в предложении GROUP BY, имеет общее значение. Логика агрегирования означает, что заданный в SELECT список полей группирующего запроса резко ограничен полями, указанными в качестве аргументов в предложении GROUP BY. Поля, имеющие спецификации, соответствующие этим требованиям, часто называются группируемыми. Если вы задаете столбец или выражение поля, которые не являются группируемыми, то запрос будет отменен.
* Столбец базы данных или неагрегатное выражение не могут быть указаны в списке столбцов, если они не указаны в предложении GROUP BY.
* Агрегатное выражение, оперирующее со столбцом базы данных, который не находится в предложении GROUP BY, может быть включено в список столбцов. Строго рекомендуется использовать алиас для результата такого выражения.