-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathproc_zlicz_uczestnikow.sql
37 lines (32 loc) · 1.09 KB
/
proc_zlicz_uczestnikow.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
-- Procedura która zlicza uczestników danej sztuki walki z podziałem na płeć
-- Przyjmuje jeden prametr - sztukę walki
IF EXISTS (SELECT 1 FROM sys.objects WHERE TYPE = 'P' AND name = 'zliczUczestnikow')
DROP PROCEDURE zliczUczestnikow;
GO
CREATE PROCEDURE zliczUczestnikow
@sztukaWalki varchar(20)
AS
BEGIN
DECLARE @kobiety int, @mezczyzni int, @razem int;
SELECT @kobiety = COUNT(*)
FROM SSW..uczestnicy AS u
JOIN SSW..zapisy AS z ON z.uczestnikId = u.id
JOIN SSW..zajecia AS z2 ON z.zajeciaId = z2.id
JOIN SSW..sztuki_walki AS sw ON z2.sztuki_walkid = sw.id
WHERE sw.nazwa = @sztukaWalki AND u.plec = 'K'
SELECT @mezczyzni = COUNT(*)
FROM SSW..uczestnicy AS u
JOIN SSW..zapisy AS z ON z.uczestnikId = u.id
JOIN SSW..zajecia AS z2 ON z.zajeciaId = z2.id
JOIN SSW..sztuki_walki AS sw ON z2.sztuki_walkid = sw.id
WHERE sw.nazwa = @sztukaWalki AND u.plec = 'M'
SET @razem = @kobiety + @mezczyzni;
SELECT @mezczyzni AS mezczyzn, @kobiety AS kobiet, @razem AS razem
END
GO
-------------------------------------------------------------
--SPRAWDZENIE--
BEGIN
EXEC zliczUczestnikow 'karate'
END
GO