This commit is contained in:
2024-03-13 00:33:46 +01:00
commit e124a47765
19374 changed files with 9806149 additions and 0 deletions

View File

@@ -0,0 +1,64 @@
/*
Minden olyan esetben amikor egy osztályhoz tartozó csoportokat kell meghatározni,
akkor az alábbi módon kell ezeket megadni:
a. Egy osztályhoz tartozik minden olyan csoport, amelynek tagja az osztály bármelyik tanulója.
Tehát ha egy osztályból akár egyetlen tanuló is tagja egy csoportnak, akkor az az osztályhoz is kapcsolódik.
b. Továbbá egy osztályhoz mindig kapcsolódnak az osztálybontásosnak jelölt csoportjaik is,
függetlenül attól, hogy abban van-e tanuló!
*/
DROP FUNCTION IF EXISTS fnGetKapcsolodoOsztalycsoportok
GO
CREATE FUNCTION fnGetKapcsolodoOsztalycsoportok (
@osztalyCsoportId int
)
RETURNS @ocs TABLE (ID int)
AS BEGIN
DECLARE @kategoriaId int = (SELECT C_FELADATKATEGORIAID FROM T_OSZTALYCSOPORT_OSSZES WHERE ID = @osztalyCsoportId)
INSERT INTO @ocs
SELECT @osztalyCsoportId AS ID /* Önmaga */
UNION
SELECT ID /* Osztály esetén, a bontott csoportok */
FROM T_CSOPORT_OSSZES
WHERE C_OSZTALYBONTASID = @osztalyCsoportId AND TOROLT = 'F'
UNION
SELECT C_OSZTALYBONTASID AS ID /* Csoport esetén, a ha bontott, akkor az osztálya */
FROM T_CSOPORT_OSSZES
WHERE ID = @osztalyCsoportId
AND C_OSZTALYBONTASID IS NOT NULL AND TOROLT = 'F'
UNION
SELECT ID /* Csoport esetén, a ha bontott, akkor az osztályának a többi csoportbontása */
FROM T_CSOPORT_OSSZES
WHERE C_OSZTALYBONTASID IN (
SELECT C_OSZTALYBONTASID FROM T_CSOPORT_OSSZES
WHERE ID = @osztalyCsoportId AND TOROLT = 'F'
) AND TOROLT ='F'
UNION
SELECT tcs2.C_OSZTALYCSOPORTID /* Azok az osztálycsoportok, ahová járnak tanulók a @osztalyCsoportId-ból */
FROM T_TANULOCSOPORT_OSSZES tcs
INNER JOIN T_TANULOCSOPORT_OSSZES tcs2 ON tcs2.C_TANULOID = tcs.C_TANULOID
INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs ON ocs.ID = tcs2.C_OSZTALYCSOPORTID
--NOTE: A T_CSOPORT_OSSZES INNER JOIN-ra azért van szükség, mert az AMI-nál visszaadná a többi osztályt is, amibe még jár, de azok nem kapcsolódóak.
INNER JOIN T_CSOPORT_OSSZES cs ON cs.ID = ocs.ID
INNER JOIN T_TANEV_OSSZES tanev ON tanev.ID = tcs.C_TANEVID AND tanev.TOROLT = 'F'
WHERE tcs.C_OSZTALYCSOPORTID = @osztalyCsoportId
AND tcs.C_BELEPESDATUM <= GETDATE() AND (tcs.C_KILEPESDATUM > GETDATE() OR tcs.C_KILEPESDATUM IS NULL OR tcs.C_KILEPESDATUM >= tanev.C_UTOLSOTANITASINAP)
AND tcs2.C_BELEPESDATUM <= GETDATE() AND (tcs2.C_KILEPESDATUM > GETDATE() OR tcs2.C_KILEPESDATUM IS NULL OR tcs2.C_KILEPESDATUM >= tanev.C_UTOLSOTANITASINAP)
AND tcs.TOROLT = 'F'
AND tcs2.TOROLT = 'F'
AND ocs.C_FELADATKATEGORIAID = @kategoriaId
RETURN
END
GO

View File

@@ -0,0 +1,296 @@
DROP PROCEDURE IF EXISTS uspGetTanuloErtekelesDataSetByTanulo
GO
CREATE PROCEDURE uspGetTanuloErtekelesDataSetByTanulo
@pIntezmenyId int
,@pTanevId int
,@pTanarId int
,@pTanuloId int
,@pDatum date = NULL
,@pAmiKategoriaId int
,@pFeladatKategoriaId int = NULL
,@pKiiratkozottNeJelenjenMeg bit = 1
AS BEGIN
SET NOCOUNT ON;
IF @pDatum IS NULL
SET @pDatum = CONVERT(date, GETDATE())
DECLARE
@evfolyamTipusId int
,@sql nvarchar (max)
SELECT TOP (1)
@evfolyamTipusId = tanuloOsztaly.EvfolyamTipusId
FROM
fnGetTanuloOsztaly(@pTanuloId, @pDatum, @pFeladatKategoriaId, @pKiiratkozottNeJelenjenMeg) tanuloOsztaly
ORDER BY
tanuloOsztaly.BelepesDatuma DESC
SET @sql = N'
CREATE TABLE #KapcsopodoTantargyak (
ID int
,C_FOTARGYID int
,C_NEV nvarchar (255)
,C_TARGYKATEGORIA int
,C_TANEVID int
)
CREATE TABLE #Tantargyak (
ID int
,C_FOTARGYID int
,C_NEV nvarchar (255)
,C_TARGYKATEGORIA int
,C_TANEVID int
)
INSERT INTO #KapcsopodoTantargyak (
ID
,C_FOTARGYID
,C_NEV
,C_TARGYKATEGORIA
,C_TANEVID
)
SELECT
kapcsolodoTargy.ID
,kapcsolodoTargy.C_FOTARGYID
,kapcsolodoTargy.C_NEV
,kapcsolodoTargy.C_TARGYKATEGORIA
,kapcsolodoTargy.C_TANEVID
FROM fnGetKapcsolodoTantargyak(@pIntezmenyId, @pTanevId, NULL) kapcsolodoTargy
CREATE TABLE #OsztalyCsoportIdList (
ID int PRIMARY KEY
)
INSERT INTO #OsztalyCsoportIdList (
ID
)
SELECT DISTINCT
OsztalyCsoport.ID
FROM T_TANULOCSOPORT_OSSZES TanuloCsoport
INNER JOIN T_OSZTALY_OSSZES Osztaly ON Osztaly.ID = TanuloCsoport.C_OSZTALYCSOPORTID AND Osztaly.C_ALTANEVID = TanuloCsoport.C_TANEVID
AND Osztaly.TOROLT = ''F''
INNER JOIN T_OSZTALYCSOPORT_OSSZES OsztalyCsoport ON OsztalyCsoport.ID = Osztaly.ID AND OsztalyCsoport.C_TANEVID = TanuloCsoport.C_TANEVID
AND OsztalyCsoport.TOROLT = ''F''
AND (OsztalyCsoport.C_FELADATKATEGORIAID = @pFeladatKategoriaId OR @pFeladatKategoriaId IS NULL)
INNER JOIN T_TANEV_OSSZES Tanev ON Tanev.ID = TanuloCsoport.C_TANEVID AND Tanev.TOROLT = ''F''
WHERE TanuloCsoport.C_TANEVID = @pTanevId
AND TanuloCsoport.TOROLT = ''F''
AND TanuloCsoport.C_TANULOID = @pTanuloId
AND TanuloCsoport.C_BELEPESDATUM <= @pDatum
'
IF @pKiiratkozottNeJelenjenMeg = 1
SET @sql += N'
AND (TanuloCsoport.C_KILEPESDATUM > @pDatum OR TanuloCsoport.C_KILEPESDATUM IS NULL OR TanuloCsoport.C_KILEPESDATUM >= Tanev.C_UTOLSOTANITASINAP)
'
SET @sql += N'
INSERT INTO #Tantargyak (
ID
,C_FOTARGYID
,C_NEV
,C_TARGYKATEGORIA
,C_TANEVID
)
SELECT
NULL
,NULL
,''Magatartás/Szorgalom''
,0
,@pTanevID;
WITH tantargy_CTE (
C_TANTARGYID
,C_FOTARGYID
,C_TANEVID
) AS
(
SELECT
Foglalkozas.C_TANTARGYID
,Tantargy.C_FOTARGYID
,Tantargy.C_TANEVID
FROM T_FOGLALKOZAS_OSSZES Foglalkozas
INNER JOIN T_TANTARGY_OSSZES Tantargy ON Tantargy.ID = Foglalkozas.C_TANTARGYID AND Tantargy.C_TANEVID = Foglalkozas.C_TANEVID
AND Tantargy.TOROLT = ''F''
INNER JOIN #OsztalyCsoportIdList OsztalyCsoport ON OsztalyCsoport.ID = Foglalkozas.C_OSZTALYCSOPORTID
WHERE Foglalkozas.C_TANEVID = @pTanevId
AND Foglalkozas.TOROLT = ''F''
UNION
SELECT
OrarendiOra.C_TANTARGYID
,Tantargy.C_FOTARGYID
,Tantargy.C_TANEVID
FROM T_ORARENDIORA_OSSZES OrarendiOra
INNER JOIN T_TANTARGY_OSSZES Tantargy ON Tantargy.ID = OrarendiOra.C_TANTARGYID AND Tantargy.C_TANEVID = OrarendiOra.C_TANEVID
AND Tantargy.TOROLT = ''F''
INNER JOIN #OsztalyCsoportIdList OsztalyCsoport ON OsztalyCsoport.ID = OrarendiOra.C_OSZTALYCSOPORTID
WHERE OrarendiOra.C_TANEVID = @pTanevId
AND OrarendiOra.TOROLT = ''F''
UNION
SELECT
TanuloErtekeles.C_TANTARGYID
,Tantargy.C_FOTARGYID
,Tantargy.C_TANEVID
FROM T_TANULOERTEKELES_OSSZES TanuloErtekeles
LEFT JOIN T_TANTARGY_OSSZES Tantargy ON Tantargy.ID = TanuloErtekeles.C_TANTARGYID AND Tantargy.C_TANEVID = TanuloErtekeles.C_TANEVID
AND Tantargy.TOROLT = ''F''
'
IF @pFeladatKategoriaId = @pAmiKategoriaId
BEGIN
SET @sql += N'
INNER JOIN T_OSZTALYCSOPORT_OSSZES Osztaly ON Osztaly.ID = TanuloErtekeles.C_OSZTALYCSOPORTID AND Osztaly.C_TANEVID = TanuloErtekeles.C_TANEVID
AND Osztaly.TOROLT = ''F''
AND Osztaly.C_FELADATKATEGORIAID = @pFeladatKategoriaId
'
END
ELSE
BEGIN
SET @sql += N'
INNER JOIN T_OSZTALYCSOPORT_OSSZES Osztaly ON Osztaly.ID = TanuloErtekeles.C_ROGZITESKORITANULOOSZTALYID AND Osztaly.C_TANEVID = TanuloErtekeles.C_TANEVID
AND Osztaly.TOROLT = ''F''
AND Osztaly.C_EVFOLYAMTIPUSA = @evfolyamTipusId
AND Osztaly.C_FELADATKATEGORIAID = @pFeladatKategoriaId
'
END
SET @sql += N'
WHERE TanuloErtekeles.C_TANEVID = @pTanevId
AND TanuloErtekeles.TOROLT = ''F''
AND TanuloErtekeles.C_TANULOID = @pTanuloId
'
IF @pFeladatKategoriaId = @pAmiKategoriaId
SET @sql += N'
AND TanuloErtekeles.C_ROGZITESKORITANULOOSZTALYID IS NULL
'
ELSE
SET @sql += N'
AND TanuloErtekeles.C_ROGZITESKORITANULOOSZTALYID IS NOT NULL
'
SET @sql += N'
)
INSERT INTO #Tantargyak (
ID
,C_FOTARGYID
,C_NEV
,C_TARGYKATEGORIA
,C_TANEVID
)
SELECT DISTINCT
KapcsopolodoTantargy.ID
,KapcsopolodoTantargy.C_FOTARGYID
,KapcsopolodoTantargy.C_NEV
,KapcsopolodoTantargy.C_TARGYKATEGORIA
,KapcsopolodoTantargy.C_TANEVID
FROM tantargy_CTE
INNER JOIN #KapcsopodoTantargyak KapcsopolodoTantargy ON tantargy_CTE.C_TANTARGYID = KapcsopolodoTantargy.ID OR tantargy_CTE.C_FOTARGYID = KapcsopolodoTantargy.ID
SELECT
@pTanuloId AS TanuloId
,Tantargy.ID AS TantargyId
,Tantargy.C_NEV AS TantargyNev
,TanuloErtekeles.ID AS ID
,TanuloErtekeles.C_DATUM AS Datum
,TanuloErtekeles.C_ROGZITESDATUM AS RogzitesDatum
,TanuloErtekeles.C_TIPUSID AS TipusId
,FelhasznaloErtekelo.C_NYOMTATASINEV AS ErtekeloNyomtatasiNev
,IIF(TanuloErtekeles.ID IS NULL, NULL, CASE WHEN TanuloErtekeles.C_ERTEKELOID = @pTanarId THEN ''T'' ELSE ''F'' END) AS Modosithato
,TanuloErtekeles.CREATED AS Created
,IIF(TanuloErtekeles.C_ISMAGATARTASSZORGALOM IS NOT NULL, TanuloErtekeles.C_ISMAGATARTASSZORGALOM, IIF(Tantargy.ID IS NOT NULL, ''F'', ''T'')) AS IsMagatartasSzorgalom
,TanuloErtekeles.C_ISERTESITESELKULDVE AS IsErtesitesElkuldve
,TanuloErtekeles.C_ERTEKELESOSZTALYZATID AS ErtekelesOsztalyzatId
,TanariAtlagSuly.C_SULY AS Suly
,TanuloErtekeles.C_ERTEKELESSZOVEG AS ErtekelesSzoveg
,TanuloErtekeles.C_ERTEKELESSZOVEGROVIDNEV AS ErtekelesSzovegRovidNev
,TanuloErtekeles.C_ERTEKELESSZAZALEK AS ErtekelesSzazalek
,TanuloErtekeles.C_ERTEKELESMODID AS ErtekelesModId
,TanuloErtekeles.C_ERTEKELESTEMA AS ErtekelesTema
,TanuloErtekeles.C_MAGATARTASOSZTALYZATID AS MagatartasOsztalyzatId
,TanuloErtekeles.C_MAGATARTASSZOVEG AS MagatartasSzoveg
,TanuloErtekeles.C_MAGATARTASSZOVEGROVIDNEV AS MagatartasSzovegRovidNev
,TanuloErtekeles.C_MAGATARTASERTEKID AS MagatartasErtekId
,TanuloErtekeles.C_SZORGALOMOSZTALYZATID AS SzorgalomOsztalyzatId
,TanuloErtekeles.C_SZORGALOMSZOVEG AS SzorgalomSzoveg
,TanuloErtekeles.C_SZORGALOMSZOVEGROVIDNEV AS SzorgalomSzovegRovidNev
,TanuloErtekeles.C_SZORGALOMERTEKID AS SzorgalomErtekId
,Tantargy.C_TARGYKATEGORIA AS TantargyKategoriaId
,Fotargy.ID AS FotargyId
,Fotargy.C_NEV AS FotargyNev
,Fotargy.C_TARGYKATEGORIA AS FotargyTantargyKategoriaId
FROM #Tantargyak Tantargy
LEFT JOIN (
SELECT
TanuloErtekeles.*
FROM T_TANULOERTEKELES_OSSZES TanuloErtekeles
'
IF @pFeladatKategoriaId = @pAmiKategoriaId
SET @sql += N'
INNER JOIN T_OSZTALYCSOPORT_OSSZES Osztaly ON Osztaly.ID = TanuloErtekeles.C_OSZTALYCSOPORTID AND Osztaly.C_TANEVID = TanuloErtekeles.C_TANEVID
AND Osztaly.TOROLT = ''F''
AND Osztaly.C_FELADATKATEGORIAID = @pFeladatKategoriaId
'
ELSE
SET @sql += N'
INNER JOIN T_OSZTALYCSOPORT_OSSZES Osztaly ON Osztaly.ID = TanuloErtekeles.C_ROGZITESKORITANULOOSZTALYID AND Osztaly.C_TANEVID = TanuloErtekeles.C_TANEVID
AND Osztaly.TOROLT = ''F''
AND Osztaly.C_EVFOLYAMTIPUSA = @evfolyamTipusId
AND Osztaly.C_FELADATKATEGORIAID = @pFeladatKategoriaId
'
SET @sql += N'
WHERE TanuloErtekeles.C_TANEVID = @pTanevId
AND TanuloErtekeles.TOROLT = ''F''
AND TanuloErtekeles.C_TANULOID = @pTanuloId
'
IF @pFeladatKategoriaId = @pAmiKategoriaId
SET @sql += N'
AND TanuloErtekeles.C_ROGZITESKORITANULOOSZTALYID IS NULL
'
ELSE
SET @sql += N'
AND TanuloErtekeles.C_ROGZITESKORITANULOOSZTALYID IS NOT NULL
'
SET @sql += N'
) AS TanuloErtekeles ON (TanuloErtekeles.C_TANTARGYID = Tantargy.ID OR (TanuloErtekeles.C_TANTARGYID IS NULL AND Tantargy.ID IS NULL))
INNER JOIN T_FELHASZNALO_OSSZES FelhasznaloErtekelo ON FelhasznaloErtekelo.ID = TanuloErtekeles.C_ERTEKELOID AND FelhasznaloErtekelo.C_TANEVID = Tantargy.C_TANEVID
AND FelhasznaloErtekelo.TOROLT = ''F''
LEFT JOIN T_TANARIATLAGSULY_OSSZES TanariAtlagSuly ON TanariAtlagSuly.C_ERTEKELESMODID = TanuloErtekeles.C_ERTEKELESMODID AND TanariAtlagSuly.C_TANEVID = Tantargy.C_TANEVID
AND TanariAtlagSuly.TOROLT = ''F''
LEFT JOIN T_TANTARGY_OSSZES Fotargy ON Fotargy.ID = Tantargy.C_FOTARGYID AND Fotargy.C_TANEVID = Tantargy.C_TANEVID
AND Fotargy.TOROLT = ''F''
'
EXEC sp_executesql @sql, N'
@pIntezmenyId int
,@pTanevId int
,@pTanarId int
,@pTanuloId int
,@pFeladatKategoriaId int
,@evfolyamTipusId int
,@pDatum date
'
,@pIntezmenyId = @pIntezmenyId
,@pTanevId = @pTanevId
,@pTanarId = @pTanarId
,@pTanuloId = @pTanuloId
,@pFeladatKategoriaId = @pFeladatKategoriaId
,@evfolyamTipusId = @evfolyamTipusId
,@pDatum = @pDatum
END
GO

View File

@@ -0,0 +1,338 @@
-- =============================================
-- Description: <Előszedjük a tanuló értékeléseket a megadott paraméterek alapján>
-- =============================================
DROP PROCEDURE IF EXISTS uspGetTanuloErtekelesListDataSet
GO
CREATE PROCEDURE uspGetTanuloErtekelesListDataSet
@pTanevId int
,@pId int = NULL
,@pTanuloId int = NULL
,@pOsztalyCsoportId int = NULL
,@pCsoportTipusId int = NULL
,@pTantargyId int = NULL
,@pErtekeloId int = NULL
,@pOsztalyzatId int = NULL
,@pErtekelesModId int = NULL
,@pTipusId int = NULL
,@pDatumTol datetime = NULL
,@pDatumIg datetime = NULL
,@pRogzitesDatumTol datetime = NULL
,@pRogzitesDatumIg datetime = NULL
,@pErtekelesSzoveg nvarchar(max) = NULL
,@pErtekelesTema nvarchar(255) = NULL
,@pKellKapcsolodoCsoportok char = 'F'
,@pFeladatKategoriaId int = NULL
,@pFeladatEllatasiHelyId int = NULL
,@pEgyszerAdhatoTanuloErtekelesTipusIdListString nvarchar(255) = NULL
,@pSpecialisErtekelesOsztalyzatEnumId int = NULL
,@pSpecialisErtekelesOsztalyzatSzoveg nvarchar(255) = NULL
,@pSpecialisErtekelesOsztalyzatSzovegRovidNev nvarchar(3) = NULL
,@pSpecialisErtekelesOsztalyzatId int = NULL
,@pSpecialisErtekelesOsztalyzatTema nvarchar(255) = NULL
AS
BEGIN
SET NOCOUNT ON;
DECLARE
@sql nvarchar(max)
,@preSelectSql nvarchar(max) = ''
,@selectSql nvarchar(max)
,@joinSql nvarchar(max)
,@whereSql nvarchar(max)
,@postSelectSql nvarchar(max) = ''
SET @selectSql = N'
SELECT DISTINCT
ert.ID AS ID
,ert.C_DATUM AS Datum
,ert.C_ROGZITESDATUM AS RogzitesDatum
,ert.C_TIPUSID AS TipusId
,ert.C_ISERTESITESELKULDVE AS IsErtesitesElkuldve
,ert.C_ERTEKELESMODID AS ErtekelesModId
,ert.C_ERTEKELESTEMA AS ErtekelesTema
,ert.C_ERTEKELESOSZTALYZATID AS ErtekelesOsztalyzatId
,ert.C_ERTEKELESSZOVEG AS ErtekelesSzoveg
,ert.C_ERTEKELESSZAZALEK AS ErtekelesSzazalek
,ert.C_ISMAGATARTASSZORGALOM AS IsMagatartasSzorgalom
,ert.C_MAGATARTASOSZTALYZATID AS MagatartasOsztalyzatId
,ert.C_MAGATARTASSZOVEG AS MagatartasSzoveg
,ert.C_MAGATARTASERTEKID AS MagatartasErtekId
,ert.C_SZORGALOMOSZTALYZATID AS SzorgalomOsztalyzatId
,ert.C_SZORGALOMSZOVEG AS SzorgalomSzoveg
,ert.C_SZORGALOMERTEKID AS SzorgalomErtekId
,ert.CREATED AS Created
,ert.C_OSZTALYCSOPORTID AS OsztalyCsoportId
,ISNULL(suly.C_SULY, 100) AS ErtekelesSuly
,tantargy.ID AS TantargyId
,ISNULL(tantargy.C_NEV, ''Magatartás/Szorgalom'') AS TantargyNev
,tantargy.C_TARGYKATEGORIA AS TantargyKategoriaId
,fotargy.ID AS FotargyId
,fotargy.C_NEV AS FotargyNev
,fotargy.C_TARGYKATEGORIA AS FotargyTantargyKategoriaId
,tanulo.ID AS TanuloId
,tanulo.C_NYOMTATASINEV AS TanuloNev
,IIF(tanulo.C_NEVSORREND = ''T'', --
tanulo.C_UTONEV + '' '' + tanulo.C_VEZETEKNEV, --
tanulo.C_VEZETEKNEV + '' '' + tanulo.C_UTONEV
) AS TanuloNevElotagNelkul
,tanar.ID AS ErtekeloId
,tanar.C_NYOMTATASINEV AS ErtekeloNyomtatasiNev
,IIF(tanar.C_NEVSORREND = ''T'', --
tanar.C_UTONEV + '' '' + tanar.C_VEZETEKNEV, --
tanar.C_VEZETEKNEV + '' '' + tanar.C_UTONEV
) AS ErtekeloNyomtatasiNevElotagNelkul
,ocs.C_NEV AS OsztalyCsoportNev
,ocs.C_FELADATKATEGORIAID AS FeladatKategoriaId
,rogziteskoriTanuloOsztaly.ID AS RogziteskoriTanuloOsztalyId
,rogziteskoriTanuloOsztaly.C_EVFOLYAMTIPUSA AS RogziteskoriTanuloOsztalyEvfolyamTipusId
FROM T_TANULOERTEKELES_OSSZES ert'
SET @joinSql = N'
LEFT JOIN T_TANARIATLAGSULY_OSSZES suly ON suly.C_TANEVID = ert.C_TANEVID
AND suly.TOROLT = ''F''
AND suly.C_ERTEKELESMODID = ert.C_ERTEKELESMODID
LEFT JOIN T_TANTARGY_OSSZES tantargy ON tantargy.C_TANEVID = ert.C_TANEVID
AND tantargy.TOROLT = ''F''
AND tantargy.ID = ert.C_TANTARGYID
LEFT JOIN T_TANTARGY_OSSZES fotargy ON fotargy.C_TANEVID = ert.C_TANEVID
AND fotargy.TOROLT = ''F''
AND fotargy.ID = tantargy.C_FOTARGYID
LEFT JOIN T_OSZTALYCSOPORT_OSSZES rogziteskoriTanuloOsztaly ON rogziteskoriTanuloOsztaly.C_TANEVID = ert.C_TANEVID
AND rogziteskoriTanuloOsztaly.TOROLT = ''F''
AND rogziteskoriTanuloOsztaly.ID = ert.C_ROGZITESKORITANULOOSZTALYID
INNER JOIN T_FELHASZNALO_OSSZES tanulo ON tanulo.C_TANEVID = ert.C_TANEVID
AND tanulo.TOROLT = ''F''
AND tanulo.ID = ert.C_TANULOID
INNER JOIN T_FELHASZNALO_OSSZES tanar ON tanar.C_TANEVID = ert.C_TANEVID
AND tanar.TOROLT = ''F''
AND tanar.ID = ert.C_ERTEKELOID
INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs ON ocs.C_TANEVID = ert.C_TANEVID
AND ocs.TOROLT = ''F''
AND ocs.ID = ert.C_OSZTALYCSOPORTID'
SET @whereSql = N'
WHERE ert.C_TANEVID = @pTanevId
AND ert.TOROLT = ''F'''
IF @pId IS NOT NULL BEGIN
SET @whereSql += N'
AND ert.ID = @pId'
END
IF @pTanuloId IS NOT NULL BEGIN
SET @whereSql += N'
AND ert.C_TANULOID = @pTanuloId'
END
IF @pOsztalyCsoportId IS NOT NULL BEGIN
SET @preSelectSql += N'
CREATE TABLE #OsztalyCsoportIdList(
ID int PRIMARY KEY
)
INSERT INTO #OsztalyCsoportIdList (ID)'
IF(@pKellKapcsolodoCsoportok = 'T') BEGIN
SET @preSelectSql += N'
SELECT ID
FROM fnGetKapcsolodoOsztalycsoportok(@pOsztalyCsoportId)'
END
ELSE BEGIN
SET @preSelectSql += N'
VALUES (@pOsztalyCsoportId)
'
END
SET @joinSql += N'
LEFT JOIN T_TANULOCSOPORT_OSSZES tcs ON tcs.C_TANEVID = ert.C_TANEVID
AND tcs.TOROLT = ''F''
AND tcs.C_TANULOID = tanulo.ID
AND tcs.C_BELEPESDATUM <= GETDATE()
AND (tcs.C_KILEPESDATUM IS NULL OR tcs.C_KILEPESDATUM >= GETDATE())'
SET @whereSql += N'
AND ert.C_OSZTALYCSOPORTID IN (SELECT ID FROM #OsztalyCsoportIdList)
AND EXISTS (
SELECT 1
FROM
T_TANULOCSOPORT_OSSZES tcs
WHERE
tcs.C_TANEVID = ert.C_TANEVID
AND tcs.TOROLT = ''F''
AND tcs.C_OSZTALYCSOPORTID = @pOsztalyCsoportId
AND tcs.C_TANULOID = ert.C_TANULOID
)'
SET @postSelectSql += N'
DROP TABLE IF EXISTS #OsztalyCsoportIdList'
END
IF @pCsoportTipusId IS NOT NULL BEGIN
SET @joinSql += N'
LEFT JOIN T_CSOPORT_OSSZES csoport ON csoport.C_ALTANEVID = ert.C_TANEVID
AND csoport.TOROLT = ''F''
AND csoport.ID = ocs.ID'
SET @whereSql += N'
AND csoport.C_TIPUSA = @pCsoportTipusId'
END
IF @pTantargyId IS NOT NULL BEGIN
SET @whereSql += N'
AND tantargy.ID = @pTantargyId'
END
IF @pErtekeloId IS NOT NULL BEGIN
SET @whereSql += N'
AND tanar.ID = @pErtekeloId'
END
IF @pOsztalyzatId IS NOT NULL BEGIN
SET @whereSql += N'
AND (ert.C_ERTEKELESOSZTALYZATID = @pOsztalyzatId OR
ert.C_MAGATARTASOSZTALYZATID = @pOsztalyzatId OR
ert.C_SZORGALOMOSZTALYZATID = @pOsztalyzatId)'
END
IF @pErtekelesModId IS NOT NULL BEGIN
SET @whereSql += N'
AND ert.C_ERTEKELESMODID = @pErtekelesModId'
END
IF @pTipusId IS NOT NULL BEGIN
SET @whereSql += N'
AND ert.C_TIPUSID = @pTipusId'
END
IF @pDatumTol IS NOT NULL BEGIN
--NOTE: Ide az adott nap 00:00:00 időponttal fog bejönni.
SET @whereSql += N'
AND ert.C_DATUM >= @pDatumTol'
END
IF @pDatumIg IS NOT NULL BEGIN
--NOTE: Ide az adott nap 23:59:59 időponttal fog bejönni.
SET @whereSql += N'
AND ert.C_DATUM <= @pDatumIg'
END
IF @pRogzitesDatumTol IS NOT NULL
BEGIN
--NOTE: Ide az adott nap 00:00:00 időponttal fog bejönni.
SET @whereSql += N'
AND ert.C_ROGZITESDATUM >= @pRogzitesDatumTol'
END
IF @pRogzitesDatumIg IS NOT NULL BEGIN
--NOTE: Ide az adott nap 23:59:59 időponttal fog bejönni.
SET @whereSql += N'
AND ert.C_ROGZITESDATUM <= @pRogzitesDatumIg'
END
IF @pErtekelesSzoveg IS NOT NULL BEGIN
SET @whereSql += N'
AND (ert.C_ERTEKELESSZOVEG LIKE ''%'' + @pErtekelesSzoveg + ''%'' OR
ert.C_MAGATARTASSZOVEG LIKE ''%'' + @pErtekelesSzoveg + ''%'' OR
ert.C_SZORGALOMSZOVEG LIKE ''%'' + @pErtekelesSzoveg + ''%'')'
END
IF @pErtekelesTema IS NOT NULL BEGIN
SET @whereSql += N'
AND ert.C_ERTEKELESTEMA LIKE ''%'' + @pErtekelesTema + ''%'''
END
IF @pFeladatKategoriaId IS NOT NULL BEGIN
SET @whereSql += N'
AND ocs.C_FELADATKATEGORIAID = @pFeladatKategoriaId'
END
IF @pFeladatEllatasiHelyId IS NOT NULL BEGIN
SET @whereSql += N'
AND ocs.C_FELADATELLATASIHELYID = @pFeladatEllatasiHelyId'
END
IF (@pSpecialisErtekelesOsztalyzatEnumId) IS NOT NULL BEGIN
IF (@pSpecialisErtekelesOsztalyzatEnumId = 1/*NOTE: NemIrt*/) BEGIN
SET @whereSql += N'
--NOTE: A leküldött adat már teljesen jól formázott, de a db-ben lehetnek rossz adatok. Az összehasonlításhoz ezt csináljuk:
-- Kisbetűsítjük -> Lecseréljük a NO BREAK SPACE-eket, SPACE-ekre -> Lecseréljük az összes többszörös szóközt egyre -> Trimmelünk
AND (ert.C_TIPUSID NOT IN (' + @pEgyszerAdhatoTanuloErtekelesTipusIdListString + ') AND
LTRIM(RTRIM(REPLACE(REPLACE(REPLACE(REPLACE(LOWER(ert.C_ERTEKELESSZOVEG),CHAR(160),CHAR(32)),CHAR(32),''(¤¤)''),''¤)(¤'',''''),''(¤¤)'',CHAR(32)))) = LOWER(@pSpecialisErtekelesOsztalyzatSzoveg) AND
LTRIM(RTRIM(REPLACE(REPLACE(REPLACE(REPLACE(LOWER(ert.C_ERTEKELESSZOVEGROVIDNEV),CHAR(160),CHAR(32)),CHAR(32),''(¤¤)''),''¤)(¤'',''''),''(¤¤)'',CHAR(32)))) = LOWER(@pSpecialisErtekelesOsztalyzatSzovegRovidNev))'
END
IF (@pSpecialisErtekelesOsztalyzatEnumId = 2/*NOTE: Dicseret*/ OR
@pSpecialisErtekelesOsztalyzatEnumId = 3/*NOTE: Kituno*/) BEGIN
SET @whereSql += N'
--NOTE: A leküldött adat már teljesen jól formázott, de a db-ben lehetnek rossz adatok. Az összehasonlításhoz ezt csináljuk:
-- Kisbetűsítjük -> Lecseréljük a NO BREAK SPACE-eket, SPACE-ekre -> Lecseréljük az összes többszörös szóközt egyre -> Trimmelünk
AND (ert.C_TIPUSID IN (' + @pEgyszerAdhatoTanuloErtekelesTipusIdListString + ') AND
ert.C_ERTEKELESOSZTALYZATID = @pSpecialisErtekelesOsztalyzatId AND
LTRIM(RTRIM(REPLACE(REPLACE(REPLACE(REPLACE(LOWER(ert.C_ERTEKELESTEMA),CHAR(160),CHAR(32)),CHAR(32),''(¤¤)''),''¤)(¤'',''''),''(¤¤)'',CHAR(32)))) = LOWER(@pSpecialisErtekelesOsztalyzatTema))'
END
IF (@pSpecialisErtekelesOsztalyzatEnumId = 4/*NOTE: Mentesitve*/) BEGIN
SET @whereSql += N'
--NOTE: A leküldött adat már teljesen jól formázott, de a db-ben lehetnek rossz adatok. Az összehasonlításhoz ezt csináljuk:
-- Kisbetűsítjük -> Lecseréljük a NO BREAK SPACE-eket, SPACE-ekre -> Lecseréljük az összes többszörös szóközt egyre -> Trimmelünk
AND (ert.C_TIPUSID IN (' + @pEgyszerAdhatoTanuloErtekelesTipusIdListString + ') AND
LTRIM(RTRIM(REPLACE(REPLACE(REPLACE(REPLACE(LOWER(ert.C_ERTEKELESSZOVEG),CHAR(160),CHAR(32)),CHAR(32),''(¤¤)''),''¤)(¤'',''''),''(¤¤)'',CHAR(32)))) = LOWER(@pSpecialisErtekelesOsztalyzatSzoveg) AND
LTRIM(RTRIM(REPLACE(REPLACE(REPLACE(REPLACE(LOWER(ert.C_ERTEKELESSZOVEGROVIDNEV),CHAR(160),CHAR(32)),CHAR(32),''(¤¤)''),''¤)(¤'',''''),''(¤¤)'',CHAR(32)))) = LOWER(@pSpecialisErtekelesOsztalyzatSzovegRovidNev))'
END
END
SET @sql = @preSelectSql + @selectSql + @joinSql + @whereSql + @postSelectSql
EXEC sp_executesql @sql, N'
@pTanevId int
,@pId int = NULL
,@pTanuloId int = NULL
,@pOsztalyCsoportId int = NULL
,@pCsoportTipusId int = NULL
,@pTantargyId int = NULL
,@pErtekeloId int = NULL
,@pOsztalyzatId int = NULL
,@pErtekelesModId int = NULL
,@pTipusId int = NULL
,@pDatumTol datetime = NULL
,@pDatumIg datetime = NULL
,@pRogzitesDatumTol datetime = NULL
,@pRogzitesDatumIg datetime = NULL
,@pErtekelesSzoveg nvarchar(max) = NULL
,@pErtekelesTema nvarchar(255) = NULL
,@pFeladatKategoriaId int = NULL
,@pFeladatEllatasiHelyId int = NULL
,@pSpecialisErtekelesOsztalyzatSzoveg nvarchar(255) = NULL
,@pSpecialisErtekelesOsztalyzatSzovegRovidNev nvarchar(3) = NULL
,@pSpecialisErtekelesOsztalyzatId int = NULL
,@pSpecialisErtekelesOsztalyzatTema nvarchar(255) = NULL'
,@pTanevId = @pTanevId
,@pId = @pId
,@pTanuloId = @pTanuloId
,@pOsztalyCsoportId = @pOsztalyCsoportId
,@pCsoportTipusId = @pCsoportTipusId
,@pTantargyId = @pTantargyId
,@pErtekeloId = @pErtekeloId
,@pOsztalyzatId = @pOsztalyzatId
,@pErtekelesModId = @pErtekelesModId
,@pTipusId = @pTipusId
,@pDatumTol = @pDatumTol
,@pDatumIg = @pDatumIg
,@pRogzitesDatumTol = @pRogzitesDatumTol
,@pRogzitesDatumIg = @pRogzitesDatumIg
,@pErtekelesSzoveg = @pErtekelesSzoveg
,@pErtekelesTema = @pErtekelesTema
,@pFeladatKategoriaId = @pFeladatKategoriaId
,@pFeladatEllatasiHelyId = @pFeladatEllatasiHelyId
,@pSpecialisErtekelesOsztalyzatSzoveg = @pSpecialisErtekelesOsztalyzatSzoveg
,@pSpecialisErtekelesOsztalyzatSzovegRovidNev = @pSpecialisErtekelesOsztalyzatSzovegRovidNev
,@pSpecialisErtekelesOsztalyzatId = @pSpecialisErtekelesOsztalyzatId
,@pSpecialisErtekelesOsztalyzatTema = @pSpecialisErtekelesOsztalyzatTema
END
GO