aboutsummaryrefslogtreecommitdiff
path: root/Microsoft Access/Scolarship/Scolarship-Queries.sql
blob: 6794369170adf6f275fcfd709e1e47adc9985e53 (plain) (blame)
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
-- Връщане на ученици, които се квалифицират за някоя стипендия и имтео и сумата на тази стипендия

SELECT Ученици.ID, Ученици.[Три имена], Ученици.Клас, Ученици.Паралелка,
(
	SELECT TOP 1 [Видове стипендии].[Заглавие на стипендия]
	FROM [Видове стипендии]
	WHERE 
	(
		(
			(
				IIf([Видове стипендии].[Тип стипендия]="По Успех",
					IIf([Ученици].[Среден успех]>=[Видове стипендии].[Минимум успех] And [Ученици].[Среден успех]<=[Видове стипендии].[Максимум успех],
						True,
						False
					),
					IIf([Видове стипендии].[Тип стипендия]="По Доход",
						IIf([Ученици].[Среден доход на член от семейството]<=[Видове стипендии].[Доход граница],
							True,
							False
						),
						IIf([Видове стипендии].[Тип стипендия]="Социална",
							IIf([Ученици].[Без родител] And [Ученици].[Среден успех]>=[Видове стипендии].[Минимум успех] And [Ученици].[Среден успех]<=[Видове стипендии].[Максимум успех],
								True,
								False
							)
						)
					)
				)
			)<>False
		)
	)
	ORDER BY Размер DESC
) AS [Заглавие на стипендия],
(
	SELECT MAX([Видове стипендии].Размер)
	FROM [Видове стипендии]
	WHERE 
	(
		(
			(
				IIf([Видове стипендии].[Тип стипендия]="По Успех",
					IIf([Ученици].[Среден успех]>=[Видове стипендии].[Минимум успех] And [Ученици].[Среден успех]<=[Видове стипендии].[Максимум успех],
						True,
						False
					),
					IIf([Видове стипендии].[Тип стипендия]="По Доход",
						IIf([Ученици].[Среден доход на член от семейството]<=[Видове стипендии].[Доход граница],
							True,
							False
						),
						IIf([Видове стипендии].[Тип стипендия]="Социална",
							IIf([Ученици].[Без родител] And [Ученици].[Среден успех]>=[Видове стипендии].[Минимум успех] And [Ученици].[Среден успех]<=[Видове стипендии].[Максимум успех],
								True,
								False
							)
						)
					)
				)
			)<>False
		)
	)
) AS [Сума за стипендия]
FROM Ученици;

-- Връщане на брой ученици на дадена стипендия

SELECT [Видове стипендии].ID, [Видове стипендии].[Заглавие на стипендия], [Видове стипендии].[Тип стипендия], [Видове стипендии].Размер, 
		(
			SELECT COUNT(*)
			FROM [Квалифицирани ученици за стипендия]
			WHERE [Видове стипендии].Размер=[Квалифицирани ученици за стипендия].[Сума за стипендия]
		) AS [Брой квалифицирани ученици]
FROM [Видове стипендии];

-- Връщане на брой ученици, квалифицирани за стипендия по класове и паралелки

SELECT [Квалифицирани ученици за стипендия].Клас, [Квалифицирани ученици за стипендия].Паралелка, COUNT([Квалифицирани ученици за стипендия].ID) AS [Брой квалифицирани ученици]
FROM [Квалифицирани ученици за стипендия]
GROUP BY [Квалифицирани ученици за стипендия].Клас, [Квалифицирани ученици за стипендия].Паралелка;

-- Връщане на сумата от стипендии за изчислен период на ученик

SELECT [Квалифицирани ученици за стипендия].ID, [Квалифицирани ученици за стипендия].[Три имена], [Квалифицирани ученици за стипендия].[Заглавие на стипендия],
		(
			SELECT IIF(Ученици.[Без родител], 12, 10)
			FROM Ученици
			WHERE Ученици.ID=[Квалифицирани ученици за стипендия].ID
		) 
		AS [Брой месеци на получаване],
		([Квалифицирани ученици за стипендия].[Сума за стипендия] * [Брой месеци на получаване])
		AS [Сума за една година]
FROM [Квалифицирани ученици за стипендия];

-- Общо сума според стипендия за година

SELECT [Видове стипендии].ID, [Видове стипендии].[Заглавие на стипендия], [Видове стипендии].[Тип стипендия], [Видове стипендии].Размер, 
		IIF(0=(
				SELECT COUNT(*)
				FROM [Сума за година на ученик]
				WHERE [Сума за година на ученик].[Заглавие на стипендия]=[Видове стипендии].[Заглавие на стипендия]
			), 
			0, 
			(
				SELECT SUM([Сума за година на ученик].[Сума за една година])
				FROM [Сума за година на ученик]
				WHERE [Сума за година на ученик].[Заглавие на стипендия]=[Видове стипендии].[Заглавие на стипендия]
			)
		) AS [Общо сума за година]
FROM [Видове стипендии];

-- Общо сума според стипендия за месец

SELECT [Видове стипендии].ID, [Видове стипендии].[Заглавие на стипендия], [Видове стипендии].[Тип стипендия], [Видове стипендии].Размер, 
		IIF(0=(
				SELECT COUNT(*)
				FROM [Квалифицирани ученици за стипендия]
				WHERE [Квалифицирани ученици за стипендия].[Заглавие на стипендия]=[Видове стипендии].[Заглавие на стипендия]
			), 
			0, 
			(
				SELECT SUM([Квалифицирани ученици за стипендия].[Сума за стипендия])
				FROM [Квалифицирани ученици за стипендия]
				WHERE [Квалифицирани ученици за стипендия].[Заглавие на стипендия]=[Видове стипендии].[Заглавие на стипендия]
			)
		) AS [Общо сума за месец]
FROM [Видове стипендии];