В ЭТОЙ ГЛАВЕ МЫ ПОКАЖЕМ ВАМ КАК
ИЗВЛЕКАТЬ информацию из таблиц. Вы узнаете
как опускать или переупорядочивать столбцы
и как автоматически устранять избыточность
данных из вашего вывода. В заключение, вы
узнаете как устанавливать условие(
проверку ) которую вы можете использовать
чтобы определить какие строки таблицы
используются в выводе. Эта последняя
особенность, будет далее описана в более
поздних главах и является одной из наиболее
изящных и мощных в SQL.
СОЗДАНИЕ ЗАПРОСА
Как мы подчеркивали ранее, SQL
символизирует собой Структурированный
Язык Запросов. Запросы - вероятно наиболее
часто используемый аспект SQL. Фактически,
для категории SQL пользователей,
маловероятно чтобы кто-либо использовал
этот язык для чего-то другого. По этой
причине, мы будем начинать наше обсуждение
SQL с обсуждения запроса и как он выполняется
на этом языке.
ЧТО ТАКОЕ ЗАПРОС ?
Запрос - команда которую вы даете
вашей программе базы данных, и которая
сообщает ей чтобы она вывела определенную
информацию из таблиц в память. Эта
информация обычно посылается
непосредственно на экран компьютера или
терминала которым вы пользуетесь, хотя, в
большинстве случаев, ее можно также послать
принтеру, сохранить в файле ( как объект в
памяти компьютера ), или представить как
вводную информацию для другой команды или
процесса.
ГДЕ ПРИМЕНЯЮТСЯ ЗАПРОСЫ ?
Запросы обычно рассматриваются
как часть языка DML. Однако, так как запрос не
меняет информацию в таблицах, а просто
показывает ее пользователю, мы будем
рассматривать запросы как самостоятельную
категорию среди команд DML которые
производят действие, а не просто показывают
содержание базы данных.
Все запросы в SQL состоят из
одиночной команды. Структура этой команды
обманчиво проста, потому что вы должны
расширять ее так чтобы выполнить высоко
сложные оценки и обработки данных. Эта
команда называется - SELECT(ВЫБОР).
КОМАНДА SELECT
В самой простой форме, команда
SELECT просто инструктирует базу данных чтобы
извлечь информацию из таблицы. Например, вы
могли бы вывести таблицу Продавцов
напечатав следующее:
SELECT snum, sname, sity, comm
FROM Salespeople;
Вывод для этого запроса
показывается в Рисунке 3.1.
=============== SQL Execution Log ============
| |
| SELECT snum, sname, sity, comm |
| FROM Salespeople; |
| |
| ==============================================|
| snum sname city comm |
| ------ ---------- ----------- ------- |
| 1001 Peel London 0.12 |
| 1002 Serres San Jose 0.13 |
| 1004 Motika London 0.11 |
| 1007 Rifkin Barcelona 0.15 |
| 1003 Axelrod New York 0.10 |
===============================================
Рисунок 3.1: команда SELECT
Другими словами, эта команда
просто выводит все данные из таблицы.
Большинство программ будут также давать
заголовки столбца как выше, а некоторые
позволяют детальное форматирование вывода,
но это уже вне стандартной спецификации.
Имеется объяснение каждой части
этой команды:
- SELECT
-
Ключевое слово которое
сообщает базе данных что эта команда -
запрос. Все запросы начинаются этим
словом, сопровождаемым пробелом.
- snum, sname
-
Это - список столбцов из
таблицы которые выбираются запросом.
Любые столбцы не перечисленные здесь не
будут включены в вывод команды. Это,
конечно, не значит что они будут удалены
или их информация будет стерта из таблиц,
потому что запрос не воздействует на
информацию в таблицах; он только
показывает данные.
- FROM Salespeople
-
FROM - ключевое слово, подобно
SELECT, которое должно быть представлено в
каждом запросе. Оно сопровождается
пробелом и затем именем таблицы
используемой в качестве источника
информации. В данном случае - это таблица
Продавцов(Salespeople).
- ;
-
Точка с запятой используется
во всех интерактивных командах SQL чтобы
сообщать базе данных что команда
заполнена и готова выполниться. В
некоторых системах наклонна черта влево
(\) в строке, является индикатором конца
команды.
Естественно, запрос такого
характера не обязательно будет
упорядочивать вывод любым указанным
способом. Та же сама команда выполненная с
теми же самыми данными но в разное врем не
сможет вывести тот же самый порядок. Обычно,
строки обнаруживаются в том порядке в
котором они найдены в таблице, поскольку
как мы установили в предыдущей главе - этот
порядок произволен. Это не обязательно
будет тот порядок в котором данные
вводились или сохранялись. Вы можете
упорядочивать вывод командами SQL
непосредственно: с помощью специального
предложения. Позже, мы покажем как это
делается. А сейчас, просто усвойте, что в
отсутствии явного упорядочения, нет
никакого определенного порядка в вашем
выводе.
Наше использование возврата (
Клавиша ENTER ) является произвольным. Мы
должны точно установить как удобнее
составить запрос, в несколько строк или в
одну строку, следующим образом:
SELECT snum, sname, city, comm FROM Salespeople;
С тех пор как SQL использует точку
с запятой чтобы указывать конец команды,
большинство программ SQL обрабатывают
возврат (через нажим Возврат или клавишу ENTER
) как пробел. Это - хороша идея чтобы
использовать возвраты и выравнивание что
мы делали это ранее, чтобы сделать ваши
команды более легкими для чтения и более
правильными.
ПРОСМОТР ТОЛЬКО ОПРЕДЕЛЕННОГО
СТОЛБЦА ТАБЛИЦЫ
Команда SELECT способна извлечь
строго определенную информацию из таблицы.
Сначала, мы можем предоставить возможность
увидеть только определенные столбцы
таблицы. Это выполняется легко, простым
исключением столбцов которые вы не хотите
видеть, из части команды SELECT. Например,
запрос
SELECT sname, comm
FROM Salespeople;
будет производить вывод
показанный на Рисунке 3.2.
=============== SQL Execution Log ============
| |
| SELECT snum, comm |
| FROM Salespeople; |
| |
| ==============================================|
| sname comm |
| ------------- --------- |
| Peel 0.12 |
| Serres 0.13 |
| Motika 0.11 |
| Rifkin 0.15 |
| Axelrod 0.10 |
===============================================
Рисунок 3.2: Выбор определенных столбцов
Могут иметься таблицы которые
имеют большое количество столбцов
содержащих данные, не все из которых
являются относящимися к поставленной
задаче. Следовательно, вы можете найти
способ подбора и выбора только полезных для
Вас столбцов.
ПЕРЕУПОРЯДОЧЕНИЕ СТОЛБЦА
Даже если столбцы таблицы, по
определению, упорядочены, это не означает
что вы будете восстанавливать их в том же
порядке. Конечно, звездочка (*) покажет все
столбцы в их естественном порядке, но если
вы укажете столбцы отдельно, вы можете
получить их в том порядке котором хотите.
Давайте рассмотрим таблицу Порядков,
содержащую дату приобретения(odate), номер
продавца(snum), номер порядка(onum), и суммы
приобретения(amt):
SELECT odate, snum, onum, amt
FROM Orders;
Вывод этого запроса показан на
Рисунке 3.3.
============= SQL Execution Log =============
| |
| SELECT odate, snum, onum, amt |
| FROM Orders; |
| |
| ------------------------------------------------|
| odate snum onum amt |
| ----------- ------- ------ --------- |
| 10/03/1990 1007 3001 18.69 |
| 10/03/1990 1001 3003 767.19 |
| 10/03/1990 1004 3002 1900.10 |
| 10/03/1990 1002 3005 5160.45 |
| 10/03/1990 1007 3006 1098.16 |
| 10/04/1990 1003 3009 1713.23 |
| 10/04/1990 1002 3007 75.75 |
| 10/05/1990 1001 3008 4723.00 |
| 10/06/1990 1002 3010 1309.95 |
| 10/06/1990 1001 3011 9891.88 |
| |
===============================================
Рисунок 3.3: Реконструкция столбцов
Как вы можете видеть, структура
информации в таблицах - это просто основа
для активной перестройки структуры в SQL.
УДАЛЕНИЕ ИЗБЫТОЧНЫХ ДАННЫХ
DISTINCT (ОТЛИЧИЕ) - аргумент который
обеспечивает Вас способом устранять
двойные значения из вашего предложения SELECT.
Предположим что вы хотите знать какие
продавцы в настоящее время имеют свои
порядки в таблице Порядков. Под порядком (здесь
и далее) будет пониматься запись в таблицу
Порядков, регистрирующую приобретения
сделанные в определенный день определенным
заказчиком у определенного продавца на
определенную сумму). Вам не нужно знать,
сколько порядков имеет каждый; вам нужен
только список номеров продавцов (snum).
Поэтому Вы можете ввести:
для получения вывода показанного
в Рисунке 3.4
=============== SQL Execution Log ============
| |
| SELECT snum |
| FROM Orders; |
| |
| ============================================= |
| snum |
| ------- |
| 1007 |
| 1001 |
| 1004 |
| 1002 |
| 1007 |
| 1003 |
| 1002 |
| 1001 |
| 1002 |
| 1001 |
=============================================
Рисунок 3. 4: SELECT с дублированием номеров продавцов.
Для получения списка без
дубликатов, для удобочитаемости, вы можете
ввести следующее:
SELECT DISTINCT snum
FROM Orders;
Вывод для этого запроса показан в
Рисунке 3.5.
Другими словами, DISTINCT следит за
тем, какие значения были ранее, так что бы
они не были продублированы в списке. Это -
полезный способ избежать избыточности
данных, но важно что бы при этом вы понимали
что вы делаете. Если вы не хотите потерять
некоторые данные, вы не должны безоглядно
использовать DISTINCT, потому что это может
скрыть какую-то проблему или какие-то
важные данные. Например, вы могли бы
предположить что имена всех ваших
заказчиков различны. Если кто-то помещает
второго Clemens в таблицу Заказчиков, а вы
используете SELECT DISTINCT cname, вы не будете даже
знать о существовании двойника. Вы можете
получить не того Clemens и даже не знать об этом.
Так как вы не ожидаете избыточности, в этом
случае вы не должны использовать DISTINCT.
ПАРАМЕТРЫ DISTINCT
DISTINCT может указываться только
один раз в данном предложении SELECT. Если
предложение выбирает многочисленные пол,
=============== SQL Execution Log ============
| |
| SELECT DISTINCT snum |
| FROM Orders; |
| |
| ============================================= |
| snum |
| ------- |
| 1001 |
| 1002 |
| 1003 |
| 1004 |
| 1007 |
=============================================
Рисунок 3.5: SELECT без дублирования
DISTINCT опускает строки где все
выбранные пол идентичны. Строки в которых
некоторые значения одинаковы а некоторые
различны - будут сохранены. DISTINCT, фактически,
приводит к показу всей строки вывода, не
указывая полей ( за исключением когда он
используется внутри агрегатных функций,
как описано в Главе 6 ), так что нет никакого
смысла чтобы его повторять.
DISTINCT ВМЕСТО ALL
Вместо DISTINCT, вы можете указать -
ALL. Это будет иметь противоположный эффект,
дублирование строк вывода сохранится. Так
как это - тот же самый случай когда вы не
указываете ни DISTINCT ни ALL, то ALL - по существу
скорее пояснительный, а не действующий
аргумент.
КВАЛИФИЦИРОВАННЫЙ ВЫБОР ПРИ
ИСПОЛЬЗОВАНИИ ПРЕДЛОЖЕНИЙ
Таблицы имеют тенденцию
становиться очень большими, поскольку с
течением времени, все большее и большее
количество строк в нее добавляется.
Поскольку обычно из них только
определенные строки интересуют вас в
данное врем, SQL дает возможность вам
устанавливать критерии чтобы определить
какие строки будут выбраны для вывода.
WHERE - предложение команды SELECT,
которое позволяет вам устанавливать
предикаты, условие которых может быть или
верным или неверным для любой строки
таблицы. Команда извлекает только те строки
из таблицы для которой такое утверждение
верно. Например, предположим вы хотите
видеть имена и комиссионные всех продавцов
в Лондоне. Вы можете ввести такую команду:
SELECT sname, city
FROM Salespeople;
WHERE city = "LONDON";
Когда предложение WHERE
представлено, программа базы данных
просматривает всю таблицу по одной строке и
исследует каждую строку чтобы определить
верно ли утверждение. Следовательно, для
записи Peel, программа рассмотрит текущее
значение столбца city, определит что оно
равно "London", и включит эту строку в
вывод. Запись для Serres не будет включена, и
так далее. Вывод для вышеупомянутого
запроса показан в Рисунке 3.6.
=============== SQL Execution Log ============
| |
| SELECT sname, city |
| FROM Salespeople |
| WHERE city = 'London' |
| ============================================= |
| sname city |
| ------- ---------- |
| Peel London |
| Motika London |
=============================================
Рисунок 3.6: SELECT c предложением WHERE
Давайте попробуем пример с
числовым полем в предложении WHERE. Поле rating
таблицы Заказчиков предназначено чтобы
разделять заказчиков на группы основанные
на некоторых критериях которые могут быть
получены в итоге через этот номер. Возможно
это - форма оценки кредита или оценки
основанной на томе предыдущих приобретений.
Такие числовые коды могут быть полезны в
реляционных базах данных как способ
подведения итогов сложной информации. Мы
можем выбрать всех заказчиков с рейтингом
100, следующим образом:
SELECT *
FROM Customers
WHERE rating = 100;
Одиночные кавычки не
используются здесь потому, что оценка - это
числовое поле. Результаты запроса показаны
в Рисунке 3. 7.
Предложение WHERE совместимо с
предыдущим материалом в этой главе. Другими
словами, вы можете использовать номера
столбцов, устранять дубликаты, или
переупорядочивать столбцы в команде SELECT
которая использует WHERE. Однако, вы можете
изменять порядок столбцов для имен только в
предложении SELECT, но не в предложении WHERE.
============ SQL Execution Log =============
| |
| SELECT * |
| FROM Customers |
| WHERE rating = 100; |
| ============================================= |
| сnum cname city rating snum |
| ------ -------- ------ ---- ------ |
| 2001 Hoffman London 100 1001 |
| 2006 Clemens London 100 1001 |
| 2007 Pereira Rome 100 1001 |
=============================================
Рисунок 3.7: SELECT с числовым полем в предикате
РЕЗЮМЕ
Теперь вы знаете несколько
способов заставить таблицу давать вам ту
информацию какую вы хотите, а не просто
выбрасывать наружу все ее содержание. Вы
можете переупорядочивать столбцы таблицы
или устранять любую из них. Вы можете решать,
хотите вы видеть дублированные значения
или нет.
Наиболее важно то, что вы можете
устанавливать условие называемое
предикатом которое определяет или не
определяет указанную строку таблицы из
тысяч таких же строк, будет ли она выбрана
для вывода.
Предикаты могут становиться
очень сложными, предоставляя вам высокую
точность в решении, какие строки вам
выбирать с помощью запроса. Именно эта
способность решать точно, что вы хотите
видеть, делает запросы SQL такими мощными.
Следующие несколько глав будут посвящены, в
большей мере, особенностям которые
расширяют мощность предикатов. В Главе 4,
вам будут представлены операторы иные чем
те которые используются в условиях
предиката, а также способы объединения
многочисленных условий в единый предикат.