Лабораторные работы (А-13-07) / Ахремцев, Стрельцов / Lab51
.docxЗадание 1
Выдать статистику по учебным заведениям вашего государства только прием 1990 года. Отчет должен начинаться заголовком и цифрой общим количеством записей по запросу (по приему 90-го года). Далее таблица, включающая перечень учебных заведений с цифрами, не равными нулю.
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE Punkt1
AS
BEGIN
SET NOCOUNT ON;
select COUNT(*) as Count from gruz
where gruz.gp = '90'
select V.uch_zavedenie, COUNT(*) as Year1990_Count from gruz as G
join vuz as V on G.vuz_k = V.cod
where G.gp = '90'
group by V.uch_zavedenie
having COUNT(*) > 0
END
Задание 2
Выдать статистику по городам вашего государства. Отчет должен начинаться с соответствующего заголовка и цифры - общего количества записей по запросу. Далее таблица, включающая перечень городов с цифрами, не равными нулю.
CREATE PROCEDURE Punkt2
AS
BEGIN
SET NOCOUNT ON;
select COUNT(*) as Count_City from vuz_gorod
where nazvanie_stran = 'ГРУЗИЯ'
select COUNT(*) as All_People from gruz
select V.nazvanie_goroda, COUNT(*) as People_Count from gruz as G
join vuz_gorod as V on G.vuz_k = V.cod_vuza
group by V.nazvanie_goroda
having COUNT(*) > 0
END
GO
Задание 3
Выдать статистику по вашему государству по следующим специальностям: 0202, 0203, 0205, 0206 (общее число по каждой специальности), а также в каких учебных заведениях и сколько обучается по этим специальностям. Отчет должен начинаться с соответствующего заголовка. Далее четыре таблицы, где каждая таблица начинается с заголовка: СПЕЦИАЛЬНОСТЬ <шифр> - ВСЕГО <цифра> (не равная нулю), а заканчивается перечнем учебных заведений с цифрами, не равными нулю.
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE Punkt3
AS
BEGIN
SET NOCOUNT ON;
select *, COUNT(*) OVER() as Count from gruz as G
join vuz as V on G.vuz_k = V.cod
select G.spec, V.uch_zavedenie, COUNT(*) as Count, SUM(COUNT(*)) OVER() as Sum from gruz as G
join vuz as V on G.vuz_k = V.cod
where G.spec = '080005'
Group by G.spec, V.uch_zavedenie
HAVING COUNT(*) > 0;
select G.spec, V.uch_zavedenie, COUNT(*) as Count, SUM(COUNT(*)) OVER() as Sum from gruz as G
join vuz as V on G.vuz_k = V.cod
where G.spec = '000217'
Group by G.spec, V.uch_zavedenie
HAVING COUNT(*) > 0;
select G.spec, V.uch_zavedenie, COUNT(*) as Count, SUM(COUNT(*)) OVER() as Sum from gruz as G
join vuz as V on G.vuz_k = V.cod
where G.spec = '002201'
Group by G.spec, V.uch_zavedenie
HAVING COUNT(*) > 0;
select G.spec, V.uch_zavedenie, COUNT(*) as Count, SUM(COUNT(*)) OVER() as Sum from gruz as G
join vuz as V on G.vuz_k = V.cod
where G.spec = '000603'
Group by G.spec, V.uch_zavedenie
HAVING COUNT(*) > 0;
END
GO
Задание 4
Выдать статистику по учебным заведениям вашего государства и только по лицам мужского пола. Отчет должен начинаться с заголовка и цифры - общего количества записей по запросу (всего мужчин). Далее таблица, включающая перечень учебных заведений с цифрами, не равными нулю.
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE Punkt3
AS
BEGIN
SET NOCOUNT ON;
select COUNT(*) as Count from gruz
where gruz.pol = 'Ì';
select V.uch_zavedenie, COUNT(*) as M_Count from gruz as G
join vuz as V on G.vuz_k = V.cod
where G.pol = 'Ì'
group by V.uch_zavedenie
having COUNT(*) > 0
END
GO
Задание 5
Выдать статистику по всем специальностям вашего государства и только по студентам, заканчивающим учебу в 1994 году. Отчет должен начинаться с соответствующего заголовка и цифры - общего количества записей по запросу (всего студентов-выпускников 1994 г.). Далее таблица, включающая перечень шифров специальностей с цифрами, не равными нулю.
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE Punkt5
AS
BEGIN
SET NOCOUNT ON;
select COUNT(*) as Count from gruz
where gruz.gok = '94'
select G.spec, COUNT(*) as Count from gruz as G
join vuz as V on G.vuz_k = V.cod
where G.gok = '94'
group by G.spec
having COUNT(*) > 0
END
GO
Задание 6
Выдать статистику по годам приема учащихся вашего государства. Отчет должен начинаться с соответствующего заголовка и цифры - общего количества записей по запросу. Далее таблица, включающая перечень годов приема с цифрами, не равными нулю.
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE Punkt6
AS
BEGIN
select SUM(COUNT(*)) OVER() as Sum_YearPriema from gruz
group by gp
select G.gp as YearPriema, COUNT(*) as Count_YearPriema from gruz as G
group by G.gp
having COUNT(*) > 0
END
GO
Задание 7
Выдать статистику по годам окончания учебы учащихся вашего государства. Отчет должен начинаться с соответствующего заголовка и цифры - общего количества записей по запросу. Далее таблица, включающая перечень годов окончания с цифрами, не равными нулю.
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE Punkt7
AS
BEGIN
SET NOCOUNT ON;
select SUM(COUNT(*)) OVER() as Sum_YearEnd from gruz
group by gok
select G.gok as YearEnd, COUNT(*) as Count_YearEnd from gruz as G
group by G.gok
having COUNT(*) > 0
END