Академический Документы
Профессиональный Документы
Культура Документы
Пример 1.
Определить общий объем читаемых дисциплин.
SELECT SUM(volume)
FROM SUB
Столбцы результирующей таблицы, которых не существовало в исходных
таблицах, называются вычисляемыми. Таким столбцам СУБД присваивает системные
имена, что не всегда является удобным.
Результат запроса:
Expr1000
500
Пример 2.
Определить количество студентов, которые посетили хоть один экзамен.
SELECT COUNT(studnum)AS COUNT
FROM STUD
Результат запроса:
COUNT
6
Несмотря на то, что реальное число таких студентов в таблице STUD равно 3,
СУБД возвращает число 6. Такой результат объясняется тем, что СУБД подсчитывает все
строки в таблице STUD, не обращая внимание на то, что в строках есть одинаковые
2
значения. Если до применения агрегатной функции необходимо исключить
дублирующиеся значения, следует перед именем столбца указать ключевое слово
DISTINCT.
SELECT COUNT(DISTINCT studnum)AS COUNT
FROM STUD
Результат запроса:
COUNT
3
Пример 3.
Определить максимальную оценку студента с номером 1.
SELECT MAX(mark)AS MAX
FROM EXAM
WHERE studnum=1
Результат запроса:
MAX
5
Предложение GROUP BY
Использование GROUP BY позволяет разбивать таблицу на логические группы и
применять агрегатные функции к каждой из этих групп. В результате получим
единственное значение для каждой группы. Обычно предложение GROUP BY применяют,
если формулировка задачи содержит фразу «для каждого…», «каждому..» и т.п.
Пример 4.
Определить средний балл каждого студента.
SELECT studnum, AVG(mark)AS AVG
FROM EXAM
GROUP BY studnum
Выполнение запроса можно описать следующим образом: СУБД разбивает
таблицу PD на три группы, в каждую из групп помещаются строки с одинаковым
значением номера поставщика (см. рисунок). Затем к каждой из полученных групп
применяется агрегатная функция SUM, что дает единственное итоговое значение для
каждой группы.
3
Результат запроса:
studnum AVG
1 4
2 5
3 2
Результат запроса:
subnum COUNT AVG
1 3 4
2 2 4,5
Предложение HAVING
Пример 6
Определить номера студентов, средний балл которых превышает балл 3.
SELECT studnum, AVG(mark)AS SUM
FROM EXAM
GROUP BY studnum
HAVING AVG(mark)>3
Результат запроса:
studnum AVG
1 4
2 5
Пример 7
Определить номера студентов, которые cдавали только один экзамен.
SELECT studnum, COUNT(distinct subnum)AS COUNT
FROM EXAM
GROUP BY studnum
HAVING COUNT(distinct subnum)=1
Результат запроса:
studnum COUNT
3 1
5
Предложение ORDER BY
subnum
1
2
Пример 10
Определить номера первых двух предметов с наименьшим объемов часов.
SELECT TOP 2 subnum
FROM SUB
ORDER BY subvolume ASC
6
Стандарт SQL требует, чтобы при сортировке NULL-значения трактовались либо
как превосходящие, либо как уступающие по сравнению со всеми остальными
значениями. Так как конкретный вариант стандартом не оговаривается, то в зависимости
от используемой СУБД при сортировке NULL-значения следуют до или после остальных
значений. В MS SQL Server NULL-значения считаются уступающими по сравнению с
остальными значениями.
Следует отметить, что если в таблице SUB будут два предмета без указания
объема часов, то именно их и отобразит предыдущий запрос. Поэтому при наличии
NULL-значений их необходимо исключать с помощью предложения WHERE. Пример 10
можно преобразовать следующий образом:
SELECT TOP 2 subnum
FROM SUB
WHERE subvolume IS NOT NULL
ORDER BY subvolume ASC