- •Iso (международной организацией по
- •2 Понимание sql
- •Что такое - реляционная база данных?
- •Порядок строк произволен
- •4 Понимание sql ___________________________________________________________________
- •Идентификация строк ( первичные ключи )
- •Столбцы именуются и нумеруются
- •8 Понимание sql
- •************** Работа с sql **************
- •Sql : обзор
- •Что делает ansi ?
- •Интерактивный и вложенный sql
- •14 Понимание sql
- •Субподразделения sql
- •16 Понимание sql
- •Sql несогласованности
- •Что такое - пользователь?
- •18 Понимание sql
- •Условия и терминология
- •************** Работа с sql **************
- •24 Понимание sql
- •26 Понимание sql
- •Переупорядочение столбца
- •28 Понимание sql
- •Параметры distinct
- •30 Понимание sql
- •32 Понимание sql
- •************* Работа с sql ***************
- •38 Понимание sql
- •40 Понимание sql
- •42 Понимание sql
- •44 Понимание sql
- •Использование специальных операторов в условиях
- •50 Понимание sql
- •52 Понимание sql
- •54 Понимание sql
- •56 Понимание sql
- •************** Работа с sql **************
- •Обобщение данных с помощью агрегатных функций
- •64 Понимание sql
- •66 Понимание sql
- •Включение дубликатов в агрегатные функции
- •Предложение group by
- •68 Понимание sql
- •Предложение having
- •70 Понимание sql
- •72 Понимание sql
- •************** Работа с sql **************
- •Формирование выводов запросов
- •Помещение текста в вашем выводе запроса
- •78 Понимание sql
- •80 Понимание sql
- •82 Понимание sql
- •Упорядочение вывода по номеру столбца
- •84 Понимание sql
- •************** Работа с sql **************
- •Запрашивание многочисленых таблиц также как одной
- •90 Понимание sql
- •92 Понимание sql
- •94 Понимание sql
- •************** Работа с sql **************
- •Объединение таблицы с собой
- •Псевдонимы
- •100 Понимание sql
- •Устранение избыточности
- •102 Понимание sql
- •Больше псевдонимов
- •104 Понимание sql
- •106 Понимание sql
- •************** Работа с sql **************
- •Вставка одного запроса внутрь другого
- •112 Понимание sql
- •114 Понимание sql
- •116 Понимание sql
- •In определяет набор значений, одно из которых должно совпадать с другим
- •118 Понимание sql
- •In является подходящим, если запрос может ограниченно производить одно
- •120 Понимание sql
- •122 Понимание sql
- •*************** Работа с sql *************
- •Соотнесенные подзапросы
- •130 Понимание sql
- •132 Понимание sql
- •Соотнесенные подзапросы в предложении having
- •134 Понимание sql
- •*************** Работа с sql *************
- •Использование оператора exists
- •140 Понимание sql
- •142 Понимание sql
- •144 Понимание sql
- •146 Понимание sql
- •************** Работа с sql **************
- •Использование оператора exists
- •152 Понимание sql
- •154 Понимание sql _____________________________________________________________________
- •156 Понимание sql
- •158 Понимание sql
- •160 Понимание sql
- •162 Понимание sql
- •Использование count вместо exists
- •166 Понимание sql
- •************** Работа с sql **************
120 Понимание sql
______________________________________________________________________
ГЛ. 10
Между прочим, префикс таблицы для поля city необязателен в предыду-
щем примере, несмотря на возможную неоднозначность между полями city
таблицы Заказчика и таблицы Продавцов.
SQL всегда ищет первое поле в таблице обозначенной в предложении
FROM текущего подзапроса.
Если поле с данным именем там не найдено, проверяются внешние запросы.
В вышеупомянутом примере, "city" в предложении WHERE означает что име-
ется ссылка к Customer.city( поле city таблицы Заказчиков).
Так как таблица Заказчиков указана в предложении FROM текущего запроса,
SQL предполагает что это - правильно. Это предположение может быть отме-
нено полным именем таблицы или префиксом псевдонима, о которых мы
поговорим позже когда будем говорить об соотнесенных подзапросах. Если
возможен беспорядок, конечно же, лучше всего использовать префиксы.
ПОДЗАПРОСЫ ВЫБИРАЮТ ОДИНОЧНЫЕ СТОЛБЦЫ
Смысл всех подзапросов обсужденных в этой главе тот, что все они выбирают
одиночный столбец. Это обязательно, поскольку выбранный вывод сравнивает-
ся с одиночным значением. Подтверждением этому то, что SELECT * не мо-
жет использоваться в подзапросе. Имеется исключение из этого, когда подзап-
росы используются с оператором EXISTS, который мы будем представлять в
Главе 12.
ИСПОЛЬЗОВАНИЕ ВЫРАЖЕНИЙ В ПОДЗАПРОСАХ
Вы можете использовать выражение основанное на столбце, а не просто сам
столбец, в предложении SELECT подзапроса. Это может быть выполнено или
с помощью реляционных операторов или с IN. Например, следующий запрос
использует реляционный оператор = ( вывод показывается в Рисунке 10.6 ):
SELECT *
FROM Customers
WHERE cnum =
( SELECT snum + 1000
FROM Salespeople
WHERE sname = Serres );
Он находит всех заказчиков чье значение поля cnum равное 1000, выше поля
snum Serres. Мы предполагаем что столбец sname не имеет никаких двойных
значений ( это может быть предписано или UNIQUE INDEX, обсуждаемым
в Главе 17, или ограничением UNIQUE, обсуждаемым в Главе 18 ); иначе
РАЗМЕЩЕНИЕ ЗАПРОСОВ ВНУТРИ ДРУГА ДРУГА 121
______________________________________________________________________
=============== SQL Execution Log ============
| |
| SELECT * |
| FROM Customers |
| WHERE cnum = |
| (SELECT snum + 1000 |
| WHERE Salespeople |
| WHERE sname = 'Serres' |
| ============================================= |
| cnum cname city rating snum |
| ----- -------- ---- ------ ----- |
| 2002 Giovanni Rome 200 1003 |
=============================================
Рисунок 10.6: Использование подзапроса с выражением
подзапрос может произвести многочисленые значения. Когда поля snum и
сnum не имеют такого простого функционального значения как например
первичный ключ , что не всегда хорошо, запрос типа вышеупомянутого
невероятно полезен.
ПОДЗАПРОСЫ В ПРЕДЛОЖЕНИИ HAVING
Вы можете также использовать подзапросы внутри предложения HAVING.
Эти подзапросы могут использовать свои собственные агрегатные функции
если они не производят многочисленых значений или использовать
GROUP BY или HAVING. Следующий запрос является этому примером
( вывод показывается в Рисунке 10.7 ):
SELECT rating, COUNT ( DISTINCT cnum )
FROM Customers
GROUP BY rating
HAVING rating >
( SELECT AVG (rating)
FROM Customers
WHERE city = " San Jose';