379 lines
No EOL
13 KiB
Transact-SQL
379 lines
No EOL
13 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,
|
|
@isKlebersberg BIT
|
|
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
|
|
FORMAT(c_napdatuma, 'yyyy') Ev,
|
|
FORMAT(c_napdatuma, 'MM') 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
|
|
f.C_NYOMTATASINEV TanarNev
|
|
,f.C_OKTATASIAZONOSITO OktatasiAzonosito
|
|
,munkakor.C_NAME Munkakor
|
|
,dbo.fnGetDokumentumPedagogusOraszam(f.id, @isKlebersberg) KotelezoOraszam
|
|
,ISNULL(CONVERT(NVARCHAR(MAX),m.C_MUNKAIDOKEDVEZMENYORASZAM),'-') MunkaidoKedvezmenyOraszam
|
|
,ISNULL(munkaidoKedvezmenyOka.C_NAME,'-') MunkaidoKedvezmenyOka
|
|
,ia.C_NEV + ' (' + ia.C_OMKOD +')' IntezmenyNeve
|
|
,ia.C_IGAZGATONEVE Igazgato
|
|
FROM T_FELHASZNALO_OSSZES f
|
|
INNER JOIN T_MUNKAUGYIADATOK_OSSZES m ON m.C_ALKALMAZOTTID = f.Id
|
|
LEFT JOIN T_DICTIONARYITEMBASE_OSSZES munkakor ON munkakor.Id = m.C_MUNKAKORTIPUSA AND munkakor.C_TANEVID = m.C_TANEVID
|
|
LEFT JOIN T_DICTIONARYITEMBASE_OSSZES munkaidoKedvezmenyOka ON munkaidoKedvezmenyOka.Id = m.C_MUNKAIDOKEDVEZMENYOKA AND munkaidoKedvezmenyOka.C_TANEVID = m.C_TANEVID
|
|
INNER JOIN T_INTEZMENYADATOK_OSSZES ia ON ia.C_TANEVID = f.C_TANEVID
|
|
WHERE
|
|
f.ID = @tanarId
|
|
AND ia.TOROLT = 'F'
|
|
AND m.TOROLT = 'F'
|
|
|
|
--===================================
|
|
--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_OSZTALYCSOPORT_OSSZES on T_TANITASIORA_OSSZES.C_OSZTALYCSOPORTID = T_OSZTALYCSOPORT_OSSZES.ID
|
|
LEFT JOIN T_CSOPORT_OSSZES ON T_CSOPORT_OSSZES.Id = T_OSZTALYCSOPORT_OSSZES.ID
|
|
WHERE
|
|
T_TANITASIORA_OSSZES.C_ORATULAJDONOSID = @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_TANITASIORA_OSSZES.C_MEGTARTOTT = 'T'
|
|
AND T_TANITASIORA_OSSZES.C_HELYETTESITOTANARID IS NULL
|
|
AND (T_CSOPORT_OSSZES.Id IS NULL OR T_CSOPORT_OSSZES.C_TIPUSA = 1034)
|
|
AND (T_TANITASIORA_OSSZES.C_PARHUZAMOSORA = 'F' OR T_TANITASIORA_OSSZES.C_PARHUZAMOSORA IS NULL)
|
|
)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
|
|
AND (tao.C_PARHUZAMOSORA = 'F' OR tao.C_PARHUZAMOSORA IS NULL)
|
|
)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
|
|
AND (tao.C_PARHUZAMOSORA = 'F' OR tao.C_PARHUZAMOSORA IS NULL)
|
|
)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
|
|
AND (tao.C_PARHUZAMOSORA = 'F' OR tao.C_PARHUZAMOSORA IS NULL)
|
|
)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
|
|
INNER JOIN T_FOGLALKOZASOK_TANAROK ft on ft.C_FOGLALKOZASOKID=fog.ID AND ft.c_tanarokid=@tanarId
|
|
INNER JOIN T_CSOPORT_OSSZES ON T_CSOPORT_OSSZES.Id = ocs.ID
|
|
WHERE
|
|
DATEPART(MONTH, tao.C_DATUM) = @Honap
|
|
AND tao.TOROLT = 'F'
|
|
AND tao.C_TANEVID = @tanevId
|
|
AND T_CSOPORT_OSSZES.C_TIPUSA <> 1034
|
|
AND (tao.C_PARHUZAMOSORA = 'F' OR tao.C_PARHUZAMOSORA IS NULL)
|
|
)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
|
|
AND (tao.C_PARHUZAMOSORA = 'F' OR tao.C_PARHUZAMOSORA IS NULL)
|
|
)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
|
|
,ROUND(DATEPART(HOUR,C_VEGE-C_KEZDETE)+CONVERT(FLOAT,DATEPART(MINUTE,C_VEGE-C_KEZDETE))/60,1) 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
|
|
,ROUND(DATEPART(hour,C_VEGE-C_KEZDETE)+CONVERT(FLOAT,DATEPART(MINUTE,C_VEGE-C_KEZDETE))/60,1) 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 |