LastName AS [Last Name],
Email AS EMAIL
Phone CELL
FROM
customers
В данном запросе для первых трех полей мы использовали ключевое слово AS. Затем для поля Phone, которое мы переименовали в CELL, ключевое слово AS мы опустили. Если созданный вами псевдоним содержит несколько слов (например, имя и фамилию), его необходимо разграничить, в данном случае либо одинарными кавычками '', либо квадратными скобками [], как показано в примере. Поскольку псевдонимы EMAIL и CELL представляют собой отдельные слова, нет необходимости их заключать в кавычки или скобки.
Примечание
В SQL существует множество вариантов синтаксиса псевдонимов. Другие РСУБД могут не распознавать все перечисленные здесь варианты псевдонимов. Если при выполнении запроса обнаружена синтаксическая ошибка, проверьте, как вы указали псевдоним.
Как показано на рис. 36, в расположенных слева выходных данных имена полей не меняются. Расположенные справа выходные данные показывают, как при использовании псевдонимов изменились имена столбцов. При добавлении псевдонима данные в базе данных не изменяются. Псевдонимы изменяют только способ отображения полей на панели результатов.
Рис. 36
Практические задания
• Добавьте к запросу еще одно поле и укажите для него псевдоним.
• Попрактикуйтесь в изменении синтаксиса псевдонима, попробуйте исключить ключевое слово AS. Проанализируйте результат.
Примечание
Не используйте никакие ключевые слова SQL в качестве псевдонимов. Это вызовет путаницу или синтаксические ошибки. РСУБД может интерпретировать данный псевдоним как команду.
Условие ORDER BY
Предположим, что службе поддержки необходим список клиентов sTunes. Целесообразно упорядочить полученные результаты по фамилии клиентов. Чтобы сделать это, надо использовать новое условие после условия FROM. Условие ORDERBY используется для сортировки данных в порядке возрастания или убывания на основе одного или нескольких столбцов. По умолчанию данные будут отсортированы в порядке возрастания от A до Z. Специальное ключевое слово ASC, определяющее порядок сортировки, необязательно. Для сортировки в порядке убывания от Z до A необходимо после сортируемого поля добавить ключевое слово DESC. Например, запрос ORDERBYLastNameDESC сортирует столбец с псевдонимом LastName в порядке убывания.
/*
CREATED BY: Уолтер Шилдс
CREATED ON: 13.03.2018
DESCRIPTION: Данный запрос осуществляет выборку полей имени, фамилии и электронной почты из таблицы customers (клиенты), отсортированных
по фамилии (Last Name).
*/
SELECT
FirstName AS [First Name],
LastName AS [Last Name],
Email AS [EMAIL]
FROM
customers
ORDER BY
LastName ASC
Рис. 37
Примечание
Если условие ORDER BY отсутствует, каждый запрос будет возвращать данные в том порядке, в котором они были изначально сохранены в таблице.
Рис. 38
Также условие ORDERBY мы можем использовать для сортировки по нескольким столбцам. В данном примере мы выполним сначала сортировку по имени (по алфавиту), а затем по фамилии (в обратном порядке). Для этого нам необходимо в условии ORDERBY указать два поля. При перечислении нескольких полей их необходимо разделять запятыми.
/*
CREATED BY: Уолтер Шилдс
CREATED ON: 13.03.2018
DESCRIPTION: Данный запрос осуществляет выборку полей имени, фамилии и электронной почты из таблицы customers (клиенты), отсортированных сначала по имени (по возрастанию), а затем по фамилии (по убыванию).
*/
SELECT
FirstName AS [First Name],
LastName AS [Last Name],
Email AS [EMAIL]
FROM
customers
ORDER BY
FirstName ASC,
LastName DESC
Выполним данный запрос и проанализируем имена клиентов, начинающиеся с буквы
Примечание
Если вы используете условие ORDER BY для столбца, в котором имеются пустые строки, вы увидите, что эти значения будут отображаться в начале списка как NULL (если сортировка осуществляется в порядке возрастания).
Практические задания
• Измените порядок полей в условии SELECT и установите LastName первым столбцом, а не вторым. Выполните запрос, в результате которого будут получены упорядоченные записи LastName. Стал ли список более читабельным?
Получение ограниченного числа записей с помощью условия LIMIT
В предыдущих примерах мы осуществляли выборку всех записей из таблицы customers. Хотя мы ограничили наши записи тремя полями и отсортировали эти поля, в панели сообщений мы видим, что каждый раз мы возвращаем 59 строк. Если нет необходимости в просмотре всех 59 записей, мы можем ограничить наши результаты определенным количеством строк. Это бывает полезно при сортировке по количеству (которое мы продемонстрируем позже), например по самой высокой цене или самым большим продажам. Если после условия ORDERBY мы добавим ключевые слова LIMIT10, в результате вернутся только первые десять записей в указанном порядке сортировки. Можно указать любое число записей, которое необходимо отобразить (при условии, что в таблице имеется такое количество записей).
/*
CREATED BY: Уолтер Шилдс
CREATED ON: 13.03.2018
DESCRIPTION: Данный запрос осуществляет выборку первых 10 записей из таблицы customers (клиентов), отсортированных сначала по имени (по возрастанию), а затем по фамилии (по убыванию).
*/
SELECT
FirstName AS [First Name],
LastName AS [Last Name],
Email AS [EMAIL]
FROM
customers
ORDER BY
FirstName ASC,
LastName DESC
LIMIT 10
Рис. 39
На нашей панели сообщений (рис. 39) теперь появилось сообщение: 10 rows returned in 1ms (10 строк вернулось за 1 мс). Сначала запрос выполняет условие ORDERBY, а затем применяет ограничение.
Примечание
Нет необходимости всегда использовать условие LIMIT вместе с ORDER BY. В большинстве случаев имеет смысл упорядочить результаты по определенным критериям, прежде чем ограничивать их. Если условие ORDER BY не используется, результаты оператора LIMIT будут возвращены в том порядке, в котором они были изначально добавлены в таблицу.
Контрольные вопросы
1. Напишите запрос, чтобы узнать количество клиентов, фамилии которых начинаются с буквы B.
2. Какая компания при сортировке в порядке убывания появляется в верхней строке таблицы customers?
3. Какое количество клиентов не указали почтовый индекс?
Резюме
• Рекомендуется добавлять комментарии к запросам. Базовый блок комментариев может содержать имя разработчика, дату создания запроса и краткое описание запроса.
• При написании запроса полезно сначала сформулировать вопрос на человеческом языке, а затем определить необходимые ключевые слова и условия.
• Запрос обычно начинается с условия SELECT, которое указывает, какие поля выводить из таблицы, указанной в условии FROM.
• Псевдонимы в SQL используются для присвоения таблице или столбцу в таблице временного имени. Псевдонимы позволяют сделать имена столбцов более удобочитаемыми. Псевдоним существует только на время выполнения запроса.
• Использование условия ORDERBY позволяет сортировать записи в алфавитном порядке (ASC) или в обратном порядке (DESC).
• С помощью условия LIMIT (после условия ORDERBY) можно получить ограниченное число записей. Для этого вам необходимо указать количество результатов, которые хотите показать.
Глава 5. Преобразование данных в информацию
На этом этапе обучения мы покажем, как, используя основной оператор SELECT, получить любой набор полей из таблицы базы данных и при необходимости упорядочить их. Отображение и сортировка полей — это важный первый шаг обучения. В дальнейшем, чтобы вы могли задавать более конкретные вопросы, понадобятся более точные инструкции. В предыдущей главе в разделе «Контрольные вопросы» мы спросили, сколько фамилий клиентов начинаются с буквы
Примечание
С этого момента мы не будем показывать окна с выходными данными браузера DB Browser (только если мы специально не ссылаемся на функцию браузера). Теперь мы будем показывать результаты наших запросов в табличной форме (рис. 40).
Рис. 40
Операторы сравнения, логические и арифметические операторы