Написать SQL- запрос, осуществляющий использование агрегатных функций

Например, оператор

Select count(*) from Pers

подсчитает полное количество записей в таблице Pers, а оператор

Select count(*) from Pers where Dep=’Бухгалтерия’

выдаст число записей сотрудников бухгалтерии. Оператор

Select count(DISTINCT Dep) from Pers

вернет число различных подразделений, упомянутых в поле Dep таблицы Pers

2. Select min(Year_r), max(Year_r), avg(Year_r) from Pers

вернет минимальное, максимальное и среднее значение года рождения, а оператор

Select min(GetDate()-Year_r), max(GetDate()-Year_r), avg(GetDate()-Year_r) from Pers

выдаст аналогичные данные, но относящиеся к возрасту сотрудников

3.Написать вложенный SQL-запрос на примере любой базы данных.

Вложенные запросы

В рамках нашего примера, допустим, что нам понадобилось узнать имена узлов, которые посещали сайт www.dom2.ru. Требуемую информацию можно получить запросом:

SELECT hst_name FROM hosts WHERE hst_pcode IN

(SELECT vis_hstcode FROM visits, sites

WHERE (sit_pcode = vis_sitcode) AND (sit_name LIKE 'www.dom2.ru'));

Рассмотрим этот запрос более пристально. Первый оператор SELECT нужен для выборки имен узлов. Чтобы выбрать требуемые нам имена, в запросе указана секция WHERE, в которой первичный ключ таблицы «Узлы» (hst_pcode) проверяется на принадлежность множеству (оператор IN). Судя по всему, множество для проверки на принадлежность должен вернуть второй оператор SELECT, находящийся в скобках. Рассмотрим его отдельно:

SELECT vis_hstcode FROM visits, sites WHERE (sit_pcode = vis_sitcode)

AND (sit_name LIKE 'www.dom2.ru')

Как видно из списка полей для выборки, запрос возвращает одно поле - vis_hstcode. Это коды узлов из таблицы «Посещения» (visits). Но после слова FROM указано две таблицы - visits и sites. Это нужно для удобства. Дело в том, что имена сайтов хранятся в таблице «Сайты» (sites), а в таблице «Посещения» - только идентификаторы сайтов. Таким образом, чтобы выбрать из таблицы «Посещения» данные только для сайта www.dom2.ru - мы связали две таблицы и указали в условии привычное для человека имя сайта. Подробнее о связывании речь пойдет чуть ниже. Таким образом, запрос, вернувший нам коды узлов будет являться вложенным запросом.

БИЛЕТ № 19


Понравилась статья? Добавь ее в закладку (CTRL+D) и не забудь поделиться с друзьями:  



double arrow
Сейчас читают про: