359 lines
No EOL
12 KiB
Transact-SQL
359 lines
No EOL
12 KiB
Transact-SQL
SET ANSI_NULLS ON
|
|
GO
|
|
SET QUOTED_IDENTIFIER ON
|
|
GO
|
|
|
|
IF OBJECT_ID('[dbo].[sp_GetMunkaidoElszamoloLap]') IS NOT NULL
|
|
BEGIN
|
|
DROP PROCEDURE [dbo].[sp_GetMunkaidoElszamoloLap]
|
|
END
|
|
GO
|
|
|
|
CREATE PROCEDURE [dbo].[sp_GetMunkaidoElszamoloLap]
|
|
@tanarid int,
|
|
@TanevId int,
|
|
@honapId int
|
|
|
|
AS
|
|
BEGIN
|
|
SET NOCOUNT ON;
|
|
|
|
DECLARE @Honap INT = (
|
|
SELECT DISTINCT
|
|
dictionaryItemBase.C_VALUE
|
|
FROM
|
|
T_DICTIONARYITEMBASE_OSSZES dictionaryItemBase
|
|
WHERE
|
|
dictionaryItemBase.ID = @honapId)
|
|
|
|
SELECT TOP 1
|
|
DATEPART(YEAR, naptariNap.C_NAPDATUMA) Ev,
|
|
DATEPART(MONTH, naptariNap.C_NAPDATUMA) Honap
|
|
FROM
|
|
T_NAPTARINAP_OSSZES naptariNap
|
|
WHERE
|
|
DATEPART(MONTH,naptariNap.C_NAPDATUMA) = @Honap AND
|
|
naptariNap.C_TANEVID = @TanevId AND
|
|
naptariNap.TOROLT = 'F'
|
|
|
|
--===================================
|
|
--FEJLÉC
|
|
--===================================
|
|
SELECT
|
|
IIF (T_INTEZMENYADATOK_OSSZES.C_ROVIDNEV IS NULL, T_INTEZMENYADATOK_OSSZES.C_NEV, T_INTEZMENYADATOK_OSSZES.C_ROVIDNEV ) IntezmenyNeve,
|
|
T_INTEZMENYADATOK_OSSZES.C_IRANYITOSZAM IntezmenyIranyitoszam,
|
|
T_INTEZMENYADATOK_OSSZES.C_VAROS IntezmenyVaros,
|
|
T_INTEZMENYADATOK_OSSZES.C_CIME IntezmenyCime,
|
|
T_INTEZMENYADATOK_OSSZES.C_TELEFONSZAM TELEFON,
|
|
T_INTEZMENYADATOK_OSSZES.C_EMAILCIM EMAILCIM,
|
|
T_INTEZMENYADATOK_OSSZES.C_OMKOD IntezmenyOMKod,
|
|
T_TANEV_OSSZES.C_NEV TANEV,
|
|
(SELECT C_NYOMTATASINEV FROM T_FELHASZNALO_OSSZES WHERE T_FELHASZNALO_OSSZES.ID = @tanarid AND T_FELHASZNALO_OSSZES.C_TANEVID = @TanevId AND T_FELHASZNALO_OSSZES.TOROLT='F') TanarNev,
|
|
@tanarid PartnerID
|
|
FROM T_INTEZMENYADATOK_OSSZES
|
|
INNER JOIN T_TANEV_OSSZES on T_TANEV_OSSZES.ID = T_INTEZMENYADATOK_OSSZES.C_TANEVID and T_TANEV_OSSZES.C_INTEZMENYID = T_INTEZMENYADATOK_OSSZES.C_INTEZMENYID and T_TANEV_OSSZES.TOROLT = 'F'
|
|
WHERE T_INTEZMENYADATOK_OSSZES.TOROLT = 'F'
|
|
and T_TANEV_OSSZES.ID = @TanevId
|
|
|
|
--===================================
|
|
--MEGTARTOTT TANÓRÁK, HELYETTESÍTÉSEK
|
|
--===================================
|
|
SELECT OsztalyCsoportID, OsztalyCsoportNev, Honap,
|
|
[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],
|
|
|
|
[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] Ossz
|
|
|
|
FROM
|
|
(
|
|
SELECT
|
|
DATEPART(DAY, T_TANITASIORA_OSSZES.C_DATUM) Nap,
|
|
DATEPART(Month, T_TANITASIORA_OSSZES.C_DATUM) Honap,
|
|
T_OSZTALYCSOPORT_OSSZES.ID OsztalyCsoportID,
|
|
T_OSZTALYCSOPORT_OSSZES.ID ocsId,
|
|
T_OSZTALYCSOPORT_OSSZES.c_nev OsztalyCsoportNev
|
|
FROM T_TANITASIORA_OSSZES
|
|
INNER JOIN T_FOGLALKOZAS_OSSZES on T_TANITASIORA_OSSZES.C_FOGLALKOZASID = T_FOGLALKOZAS_OSSZES.ID
|
|
INNER JOIN T_FOGLALKOZASOK_TANAROK on T_FOGLALKOZAS_OSSZES.ID=T_FOGLALKOZASOK_TANAROK.C_FOGLALKOZASOKID
|
|
INNER JOIN T_OSZTALYCSOPORT_OSSZES on T_FOGLALKOZAS_OSSZES.C_OSZTALYCSOPORTID = T_OSZTALYCSOPORT_OSSZES.ID
|
|
WHERE T_FOGLALKOZASOK_TANAROK.C_TANAROKID=@tanarid
|
|
AND T_TANITASIORA_OSSZES.C_TANEVID = @TanevId
|
|
AND DATEPART(MONTH, T_TANITASIORA_OSSZES.C_DATUM) = @Honap
|
|
AND T_TANITASIORA_OSSZES.TOROLT='F'
|
|
AND T_FOGLALKOZAS_OSSZES.TOROLT='F'
|
|
AND T_OSZTALYCSOPORT_OSSZES.TOROLT='F'
|
|
AND T_TANITASIORA_OSSZES.C_MEGTARTOTT='T')a
|
|
PIVOT
|
|
(
|
|
COUNT(ocsId)
|
|
FOR Nap IN ([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])
|
|
|
|
) OsszTanora
|
|
|
|
--szakszerű helyettesítés
|
|
SELECT OsztalyCsoportID, OsztalyCsoportNev, Honap,
|
|
[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],
|
|
|
|
[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] Ossz
|
|
FROM
|
|
(
|
|
SELECT
|
|
DATEPART(DAY, tao.C_DATUM) Nap,
|
|
DATEPART(MONTH,tao.C_DATUM) Honap,
|
|
ocs.C_NEV OsztalyCsoportNev,
|
|
tao.C_OSZTALYCSOPORTID oraid,
|
|
tao.C_OSZTALYCSOPORTID OsztalyCsoportID
|
|
FROM T_TANITASIORA_OSSZES tao
|
|
INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs on ocs.id=tao.C_OSZTALYCSOPORTID
|
|
WHERE tao.C_HELYETTESITOTANARID=@tanarid
|
|
AND DATEPART(MONTH, tao.C_DATUM) = @Honap
|
|
AND tao.TOROLT='F'
|
|
AND tao.C_HELYETTESITESTIPUSA=1494
|
|
AND tao.C_TANEVID=@TanevId
|
|
)a
|
|
PIVOT
|
|
(
|
|
COUNT(oraID)
|
|
FOR Nap IN ([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])
|
|
|
|
) SzakszeruHelyettesites
|
|
|
|
--nem szakszerű helyettesítés
|
|
SELECT OsztalyCsoportID, OsztalyCsoportNev, Honap,
|
|
[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],
|
|
|
|
[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] Ossz
|
|
FROM
|
|
(
|
|
SELECT
|
|
DATEPART(DAY, tao.C_DATUM) Nap,
|
|
DATEPART(MONTH,tao.C_DATUM) Honap,
|
|
ocs.C_NEV OsztalyCsoportNev,
|
|
tao.C_OSZTALYCSOPORTID oraid,
|
|
tao.C_OSZTALYCSOPORTID OsztalyCsoportID
|
|
FROM T_TANITASIORA_OSSZES tao
|
|
INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs on ocs.id=tao.C_OSZTALYCSOPORTID
|
|
WHERE tao.C_HELYETTESITOTANARID=@tanarid
|
|
AND DATEPART(MONTH, tao.C_DATUM) = @Honap
|
|
AND tao.TOROLT='F'
|
|
AND tao.C_HELYETTESITESTIPUSA=1495
|
|
AND tao.C_TANEVID=@TanevId
|
|
)a
|
|
PIVOT
|
|
(
|
|
COUNT(oraID)
|
|
FOR Nap IN ([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])
|
|
|
|
) NemSzakszeruHelyettesites
|
|
|
|
--óraösszevonás
|
|
SELECT OsztalyCsoportID, OsztalyCsoportNev, Honap,
|
|
[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],
|
|
|
|
[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] Ossz
|
|
|
|
FROM
|
|
(
|
|
SELECT
|
|
DATEPART(DAY, tao.C_DATUM) Nap,
|
|
DATEPART(MONTH,tao.C_DATUM) Honap,
|
|
ocs.C_NEV OsztalyCsoportNev,
|
|
tao.C_OSZTALYCSOPORTID oraid,
|
|
tao.C_OSZTALYCSOPORTID OsztalyCsoportID
|
|
FROM T_TANITASIORA_OSSZES tao
|
|
INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs on ocs.ID=tao.C_OSZTALYCSOPORTID
|
|
WHERE tao.C_HELYETTESITOTANARID=@tanarid
|
|
AND DATEPART(MONTH, tao.C_DATUM) = @Honap
|
|
AND tao.TOROLT='F'
|
|
AND tao.C_HELYETTESITESTIPUSA=1496
|
|
AND tao.C_TANEVID=@TanevId
|
|
)a
|
|
PIVOT
|
|
(
|
|
COUNT(oraID)
|
|
FOR Nap IN ([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])
|
|
|
|
) Oraosszevonas
|
|
|
|
--tanóránkívüli
|
|
SELECT OsztalyCsoportID, OsztalyCsoportNev, Honap,
|
|
[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],
|
|
|
|
[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] Ossz
|
|
|
|
FROM
|
|
(
|
|
SELECT
|
|
DATEPART(DAY, tao.C_DATUM) Nap,
|
|
DATEPART(MONTH,tao.C_DATUM) Honap,
|
|
ocs.C_NEV OsztalyCsoportNev,
|
|
tao.C_OSZTALYCSOPORTID oraid,
|
|
tao.C_OSZTALYCSOPORTID OsztalyCsoportID
|
|
FROM T_TANITASIORA_OSSZES tao
|
|
INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs on ocs.id=tao.C_OSZTALYCSOPORTID
|
|
INNER JOIN T_FOGLALKOZAS_OSSZES fog on fog.id=tao.C_FOGLALKOZASID AND fog.C_FOGLALKOZASTIPUSA=1371
|
|
INNER JOIN T_FOGLALKOZASOK_TANAROK ft on ft.C_FOGLALKOZASOKID=fog.ID AND ft.c_tanarokid=@tanarId
|
|
WHERE DATEPART(MONTH, tao.C_DATUM) = @Honap and tao.TOROLT='F' AND tao.C_TANEVID=@TanevId
|
|
)a
|
|
PIVOT
|
|
(
|
|
COUNT(oraID)
|
|
FOR Nap IN ([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])
|
|
|
|
) TanoranKivuli
|
|
|
|
--egyéni foglalkozas
|
|
SELECT
|
|
OsztalyCsoportID, OsztalyCsoportNev, Honap,
|
|
[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],
|
|
|
|
[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] Ossz
|
|
|
|
FROM
|
|
(
|
|
SELECT
|
|
DATEPART(DAY, tao.C_DATUM) Nap,
|
|
DATEPART(MONTH,tao.C_DATUM) Honap,
|
|
ocs.C_NEV OsztalyCsoportNev,
|
|
tao.C_OSZTALYCSOPORTID oraid,
|
|
tao.C_OSZTALYCSOPORTID OsztalyCsoportID
|
|
FROM T_TANITASIORA_OSSZES tao
|
|
INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs on ocs.id=tao.C_OSZTALYCSOPORTID
|
|
INNER JOIN T_FOGLALKOZAS_OSSZES fog on fog.id=tao.C_FOGLALKOZASID AND fog.C_FOGLALKOZASTIPUSA=1371
|
|
INNER JOIN T_FOGLALKOZASOK_TANAROK ft on ft.C_FOGLALKOZASOKID=fog.ID AND ft.C_TANAROKID=@tanarId
|
|
WHERE DATEPART(MONTH, tao.C_DATUM) = @Honap
|
|
AND tao.TOROLT='F'
|
|
AND tao.C_TANEVID=@TanevId
|
|
)a
|
|
PIVOT
|
|
(
|
|
COUNT(oraID)
|
|
FOR Nap IN ([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])
|
|
|
|
) Oraosszevonas
|
|
|
|
--============================================
|
|
--NEVELÉSSEL-OKTATÁSSAL LE NEM KÖTÖTT MUNKAIDŐ
|
|
--============================================
|
|
--ÖSSZESEN
|
|
SELECT Honap,
|
|
[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],
|
|
|
|
isnull([1],0)+isnull([2],0)+isnull([3],0)+isnull([4],0)+isnull([5],0)+
|
|
isnull([6],0)+isnull([7],0)+isnull([8],0)+isnull([9],0)+isnull([10],0)+
|
|
isnull([11],0)+isnull([12],0)+isnull([13],0)+isnull([14],0)+isnull([15],0)+
|
|
isnull([16],0)+isnull([17],0)+isnull([18],0)+isnull([19],0)+isnull([20],0)+
|
|
isnull([21],0)+isnull([22],0)+isnull([23],0)+isnull([24],0)+isnull([25],0)+
|
|
isnull([26],0)+isnull([27],0)+isnull([28],0)+isnull([29],0)+isnull([30],0)+isnull([31],0) Ossz
|
|
|
|
FROM
|
|
(
|
|
SELECT
|
|
DATEPART(DAY, C_KEZDETE) Nap,
|
|
DATEPART(MONTH, C_KEZDETE) Honap,
|
|
datepart(hour,C_VEGE-C_KEZDETE)+convert(float,datepart(MINUTE,C_VEGE-C_KEZDETE))/60 Oraszam
|
|
FROM T_NEMKOTOTTMUNKAIDO_OSSZES
|
|
WHERE
|
|
C_MEGTARTOTT='T'
|
|
AND C_TANARID=@tanarId
|
|
AND TOROLT='F'
|
|
AND DATEPART(MONTH, C_KEZDETE) = @Honap
|
|
AND DATEPART(MONTH, C_VEGE) = @Honap
|
|
) Orak
|
|
PIVOT
|
|
(
|
|
SUM(Oraszam)
|
|
FOR Nap IN ([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])
|
|
) Tevekenyseg
|
|
|
|
--a hónapban előforduló típusok
|
|
SELECT DISTINCT
|
|
C_TEVEKENYSEGTIPUSA TipusId,
|
|
d.C_NAME Tipus
|
|
FROM T_NEMKOTOTTMUNKAIDO_OSSZES
|
|
INNER JOIN (SELECT DISTINCT ID, C_NAME FROM T_DICTIONARYITEMBASE) d on d.ID=C_TEVEKENYSEGTIPUSA
|
|
WHERE
|
|
C_MEGTARTOTT='T'
|
|
AND C_TANARID=@tanarId
|
|
AND TOROLT='F'
|
|
AND DATEPART(MONTH, C_KEZDETE) = @Honap
|
|
AND DATEPART(MONTH, C_VEGE) = @Honap
|
|
|
|
--sorokra (tipusokra) lebontva
|
|
SELECT Honap,
|
|
Tipus TipusId, [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],
|
|
|
|
isnull([1],0)+isnull([2],0)+isnull([3],0)+isnull([4],0)+isnull([5],0)+
|
|
isnull([6],0)+isnull([7],0)+isnull([8],0)+isnull([9],0)+isnull([10],0)+
|
|
isnull([11],0)+isnull([12],0)+isnull([13],0)+isnull([14],0)+isnull([15],0)+
|
|
isnull([16],0)+isnull([17],0)+isnull([18],0)+isnull([19],0)+isnull([20],0)+
|
|
isnull([21],0)+isnull([22],0)+isnull([23],0)+isnull([24],0)+isnull([25],0)+
|
|
isnull([26],0)+isnull([27],0)+isnull([28],0)+isnull([29],0)+isnull([30],0)+isnull([31],0) Ossz
|
|
|
|
FROM
|
|
(
|
|
SELECT
|
|
C_TEVEKENYSEGTIPUSA Tipus,
|
|
DATEPART(DAY, C_KEZDETE) Nap,
|
|
DATEPART(MONTH, C_KEZDETE) Honap,
|
|
DATEPART(hour,C_VEGE-C_KEZDETE)+convert(float,datepart(MINUTE,C_VEGE-C_KEZDETE))/60 Oraszam
|
|
FROM T_NEMKOTOTTMUNKAIDO_OSSZES
|
|
WHERE
|
|
C_MEGTARTOTT='T'
|
|
AND C_TANARID=@tanarId
|
|
AND TOROLT='F'
|
|
AND DATEPART(MONTH, C_KEZDETE) = @Honap
|
|
AND DATEPART(MONTH, C_VEGE) = @Honap
|
|
) Orak
|
|
PIVOT
|
|
(
|
|
SUM(Oraszam)
|
|
FOR Nap IN ([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])
|
|
) Soronkent
|
|
|
|
END
|
|
|
|
GO |