Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Скачиваний:
157
Добавлен:
16.04.2013
Размер:
6.72 Mб
Скачать

Ограничение на запросы с группировкой.

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

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

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

Извлечение информации о количестве жителей с не 0-м общим доходом. В таблице результатов вывести номер жителя, ФИО, номер квартиры жителя и кол-во источников дохода.

SELECT NOM, FIO, ADR, COUNT(ID) FROM PERSON, HEVE_D

WHERE HEVE_D.NOM = PERSON.NOM

GROUP BY NOM, FIO, ADR.

30. Условия поиска групп и ограничения на эти условия.

Они задаются в предложении HAVINGи позволяют включить в конечную таблицу результатов информацию только об избранных группах.

SELECT ADR FROM PERSON

GROUP BY ADR

HAVINGCOUNT(*) > 1.

Ограничения на условия поиска групп

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

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

SELECT RDATE, SUM(SUMD) FROM PERDON

GROUP BY RDATE

HAVING RDATE < ’11-DECEMBER-2000’

31. Вложенный запрос и его особенности. Пример.

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

SELECT NOM, FIO FROM PERSON

WHERE SUMD < (SELECT MAX(MONEYS) FROM PROFIT).

Вложенный запрос – операторSELECT, заключенный в круглые скобки, и используемый в предложенияхWHEREилиHAVING.

Отличия:

  1. таблица результатов вложенного запроса всегда состоит из 1-го столбца. Список возвращаемых столбцов во вложенном запросе всегда должен иметь только 1 элемент.

  2. во вложенный запрос не может входить предложение ORDERBYдля экономии времени.

  3. вложенный запрос не может быть запросом на объединение нескольких различных операторов SELECT.

  4. особенность: имена столбцов используемых во вложенном запросе могут являться ссылками на столбцы главного или внешнего запроса.

32. Внешние ссылки и связанные подзапросы. Пример.

Определить адреса квартир, жители которых не могут оплачивать коммунальные услуги. (Стоимость коммунальных услуг определяется произведением 100 на площадь квартиры), жители могут оплачивать коммунальные услуги, если их общий доход не меньше, чем плата за коммунальные услуги.

SELECT * FROM FLAT

WHERE SKV*100>=(SELECT SUM(SUMD) FROM PERSON

WHERE PERSON.ADR = FLAT.ADR).

FLAT.ADR–внешняя ссылка, представляет собой имя столбца, принадлежащего таблице, указанной в предложенииFROMглавного запроса и не входящего ни в одну из главных таблиц, перечисленных в предложенииFROMвложенного запроса.

Если во вложенном запросе имеется внешняя ссылка, то такой запрос называется связанным.

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

Процедура выполнения запроса, в составе которого имеется связанный подзапрос.

  1. Выбрать строку из таблицы, имя которой указано в главном запросе.

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

  3. Вычислить условия поиска главного запроса с учетом результатов вложенного запроса, выполненного на шаге 2. Если условие поиска – истина, то выбранная строка из таблицы главного запроса включается в таблицу результатов. Иначе выбранная стока не включается в таблицу результатов.

  4. Повтор шагов 1-3 для строк таблиц или таблицы главного запроса, пока не будут проверены все строки.

Соседние файлы в папке бд