Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лабораторные работы (2011) / Афанасьев / Лабораторная работа 5.doc
Скачиваний:
63
Добавлен:
28.06.2014
Размер:
1.61 Mб
Скачать

Лабораторная работа 5

Вариант № 4

А-13-08

Афанасьев Сергей

Задание 1

Выдать статистику по учебным заведениям вашего государства только прием 1990 года. Отчет должен начинаться заголовком и цифрой ­общим количеством записей по запросу (по приему 90-го года). Далее таблица, включающая перечень учебных заведений с цифрами, не равными нулю.

create procedure proc1 as

select count(*) as "Всего"

from uzb

where gp='90'

select vuz.uch_zavedenie as Учебное заведение, count(*) as "Количество студентов"

from uzb

join vuz on vuz_k=vuz.cod

where (gp='90')

group by vuz.uch_zavedenie

Задание 2

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

create procedure proc2 as

select count(*) as `Всего`

from uzb

select vuz_gorod.nazvanie_goroda as "Город", count(*) as "Количество учащихся"

from uzb

join vuz_gorod on vuz_k=vuz_gorod.cod_vuza

group by vuz_gorod.nazvanie_goroda

Задание 3

Выдать статистику по вашему государству по следующим специаль­ностям: 0202, 0203, 0205, 0206 (общее число по каждой специальности), а также в каких учебных заведениях и сколько обучается по этим специ­альностям. Отчет должен начинаться с соответствующего заголовка. Да­лее четыре таблицы, где каждая таблица начинается с заголовка: СПЕЦИАЛЬНОСТЬ <шифр> - ВСЕГО <цифра> (не равная нулю), а заканчивает­ся перечнем учебных заведений с цифрами, не равными нулю.

create procedure proc3 as

select count(*) as "000203 - ВСЕГО"

from uzb

where spec='000203'

select vuz.uch_zavedenie as "Учебное заведение", count(*) as "Количество"

from uzb

join vuz on vuz_k=vuz.cod

where spec='000203'

group by vuz.uch_zavedenie

select count(*) as "000204 - ВСЕГО"

from uzb

where spec='000204'

select vuz.uch_zavedenie as "Учебное заведение", count(*) as "Количество"

from uzb

join vuz on vuz_k=vuz.cod

where spec='000204'

group by vuz.uch_zavedenie

select count(*) as "000205 - ВСЕГО"

from uzb

where spec='000205'

select vuz.uch_zavedenie as "Учебное заведение", count(*) as "Количество"

from uzb

join vuz on vuz_k=vuz.cod

where spec='000205'

group by vuz.uch_zavedenie

select count(*) as "000206 - ВСЕГО"

from uzb

where spec='000206'

select vuz.uch_zavedenie as "Учебное заведение", count(*) as "Количество"

from uzb

join vuz on vuz_k=vuz.cod

where spec='000206'

group by vuz.uch_zavedenie

Задание 4

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

create procedure proc4 as

select count(*) as Общее количество мужчин

from uzb

where pol='М'

select vuz.uch_zavedenie as Учебное заведение, count(*) as Количество мужчин

from uzb

join vuz on vuz_k=vuz.cod

where pol='М'

group by vuz.uch_zavedenie