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

View file

@ -0,0 +1,188 @@
DROP PROCEDURE IF EXISTS uspGetHelyettesitesekListaja
GO
CREATE PROCEDURE uspGetHelyettesitesekListaja
@pKezdoDatum datetime = NULL
,@pVegDatum datetime = NULL
,@pHelyettesitesTipusId int = NULL
,@pHelyettesitettId int = NULL
,@pHelyettesitoId int = NULL
,@pIsNaplozott char(1) = NULL
,@pOsztalyCsoportId int = NULL
,@pTantargyId int = NULL
,@pKellKapcsolodoCsoportok char = 'F'
AS
BEGIN
SET NOCOUNT ON
DECLARE
@sql nvarchar(max)
,@whereString nvarchar(max) = ''
IF @pKezdoDatum IS NOT NULL BEGIN
SET @whereString += N'
AND h.HelyettesitesDatum >= @pKezdoDatum'
END
IF @pVegDatum IS NOT NULL BEGIN
SET @whereString += N'
AND h.HelyettesitesDatum <= @pVegDatum'
END
IF @pHelyettesitesTipusId IS NOT NULL BEGIN
SET @whereString += N'
AND h.HelyettesitesTipusId = @pHelyettesitesTipusId'
END
ELSE BEGIN
SET @whereString += N'
AND h.HelyettesitesTipusId IS NOT NULL'
END
IF @pHelyettesitettId IS NOT NULL BEGIN
SET @whereString += N'
AND h.HelyettesitettId = @pHelyettesitettId'
END
IF @pHelyettesitoId IS NOT NULL BEGIN
SET @whereString += N'
AND h.HelyettesitoId = @pHelyettesitoId'
END
IF @pOsztalyCsoportId IS NOT NULL BEGIN
IF(@pKellKapcsolodoCsoportok = 'T')
BEGIN
SET @whereString += N'
AND h.OsztalyCsoportId IN (SELECT ID FROM fnGetKapcsolodoOsztalycsoportok(@pOsztalyCsoportId))'
END
ELSE
BEGIN
SET @whereString += N'
AND h.OsztalyCsoportId = @pOsztalyCsoportId'
END
END
IF @pTantargyId IS NOT NULL BEGIN
SET @whereString += N'
AND h.TantargyId = @pTantargyId'
END
IF @pIsNaplozott = 0 BEGIN
SET @whereString+=N'
AND h.Naplozott = ''F'''
END
ELSE IF @pIsNaplozott = 1 BEGIN
SET @whereString += N'
AND h.Naplozott = ''T'''
END
ELSE BEGIN
SET @whereString += N'
AND h.Naplozott IS NOT NULL'
END
SET @sql = N'
SELECT
HelyettesitesDatum
,Ora
,Helyettesitett
,HelyettesitettElotagNelkul
,HelyettesitettId
,HelyettesitesTipusId
,HelyettesitesOka
,C_MEGJEGYZES
,Helyettesito
,HelyettesitoElotagNelkul
,HelyettesitoId
,OsztalyCsoport
,OsztalyCsoportId
,Tantargy
,TantargyId
,Naplozott
,ID
FROM(
SELECT
h.C_HELYETTESITESNAPJA AS HelyettesitesDatum
,oo.C_ORASZAM AS Ora
,helyettesitett.C_NYOMTATASINEV AS Helyettesitett
,IIF(helyettesitett.C_NEVSORREND = ''T'',
helyettesitett.C_UTONEV + '' '' + helyettesitett.C_VEZETEKNEV,
helyettesitett.C_VEZETEKNEV + '' '' + helyettesitett.C_UTONEV) AS HelyettesitettElotagNelkul
,helyettesitett.ID AS HelyettesitettId
,h.C_HELYETTESITESTIPUS AS HelyettesitesTipusId
,h.C_HELYETTESITESOKA AS HelyettesitesOka
,'''' as C_MEGJEGYZES
,helyettesito.C_NYOMTATASINEV AS Helyettesito
,IIF(helyettesito.C_NEVSORREND = ''T'',
helyettesito.C_UTONEV + '' '' + helyettesito.C_VEZETEKNEV,
helyettesito.C_VEZETEKNEV + '' '' + helyettesito.C_UTONEV) AS HelyettesitoElotagNelkul
,helyettesito.ID AS HelyettesitoId
,ocs.C_NEV AS OsztalyCsoport
,ocs.ID AS OsztalyCsoportId
,tantargy.C_NEV AS Tantargy
,tantargy.ID AS TantargyId
,''F'' AS Naplozott
,h.ID as ID
FROM T_HELYETTESITESIIDOSZAK h
INNER JOIN T_ORARENDIORA oo ON oo.ID=h.C_HELYETTESITETTORARENDID
INNER JOIN T_TANTARGY tgy ON tgy.ID=oo.C_TANTARGYID
INNER JOIN T_FELHASZNALO helyettesitett ON oo.C_TANARID = helyettesitett.ID
INNER JOIN T_FELHASZNALO helyettesito ON h.C_HELYETTESTANAROKID= helyettesito.ID
INNER JOIN T_OSZTALYCSOPORT ocs ON oo.C_OSZTALYCSOPORTID = ocs.ID AND ocs.C_FELADATKATEGORIAID = (SELECT C_DEFAULTFELADATKATEGORIAID FROM T_TANEV WHERE ID = ocs.C_TANEVID)
INNER JOIN T_TANTARGY tantargy ON oo.C_TANTARGYID = tantargy.ID
WHERE NOT EXISTS(
SELECT 1 FROM T_TANITASIORA tao WHERE tao.C_DATUM=h.C_HELYETTESITESNAPJA AND tao.C_OSZTALYCSOPORTID=oo.C_OSZTALYCSOPORTID
AND tao.C_TANTARGYID=oo.C_TANTARGYID AND (tao.C_TANARID = h.C_HELYETTESTANAROKID OR tao.C_HELYETTESITOTANARID = h.C_HELYETTESTANAROKID) AND tao.C_HELYETTESITESTIPUSA IS NOT NULL
AND (oo.C_ORASZAM=tao.C_ORASZAM OR (oo.C_ORASZAM IS NULL AND tao.C_ORAKEZDETE=oo.C_ORAKEZDETE AND tao.C_ORAVEGE=oo.C_ORAVEGE)))
UNION ALL
SELECT
tao.C_DATUM AS HelyettesitesDatum
,tao.C_ORASZAM AS Ora
,helyettesitett.C_NYOMTATASINEV AS Helyettesitett
,IIF(helyettesitett.C_NEVSORREND = ''T'',
helyettesitett.C_UTONEV + '' '' + helyettesitett.C_VEZETEKNEV,
helyettesitett.C_VEZETEKNEV + '' '' + helyettesitett.C_UTONEV) AS HelyettesitettElotagNelkul
,helyettesitett.ID AS HelyettesitettId
,tao.C_HELYETTESITESTIPUSA AS HelyettesitesTipusId
,tao.C_HELYETTESITESOKA AS HelyettesitesOka
,tao.C_MEGJEGYZES as C_MEGJEGYZES
,helyettesito.C_NYOMTATASINEV AS Helyettesito
,IIF(helyettesito.C_NEVSORREND = ''T'',
helyettesito.C_UTONEV + '' '' + helyettesito.C_VEZETEKNEV,
helyettesito.C_VEZETEKNEV + '' '' + helyettesito.C_UTONEV) AS HelyettesitoElotagNelkul
,helyettesito.ID AS HelyettesitoId
,ocs.C_NEV AS OsztalyCsoport
,ocs.ID AS OsztalyCsoportId
,tantargy.C_NEV AS Tantargy
,tantargy.ID AS TantargyId
,''T'' AS Naplozott
,tao.ID
FROM T_TANITASIORA tao
INNER JOIN T_TANTARGY tgy ON tgy.ID=tao.C_TANTARGYID
INNER JOIN T_FELHASZNALO helyettesitett ON tao.C_TANARID= helyettesitett.ID
INNER JOIN T_FELHASZNALO helyettesito ON tao.C_HELYETTESITOTANARID= helyettesito.ID
INNER JOIN T_OSZTALYCSOPORT ocs ON tao.C_OSZTALYCSOPORTID = ocs.ID AND ocs.C_FELADATKATEGORIAID = (SELECT C_DEFAULTFELADATKATEGORIAID FROM T_TANEV WHERE ID = ocs.C_TANEVID)
INNER JOIN T_TANTARGY tantargy ON tao.C_TANTARGYID = tantargy.ID
WHERE C_HELYETTESITESTIPUSA IS NOT NULL AND tao.TOROLT=''F''
) h WHERE (1=1)
' +@whereString
EXEC sp_executesql @sql, N'
@pKezdoDatum datetime
,@pVegDatum datetime
,@pHelyettesitesTipusId int
,@pHelyettesitettId int
,@pHelyettesitoId int
,@pIsNaplozott char(1)
,@pOsztalyCsoportId int
,@pTantargyId int'
,@pKezdoDatum = @pKezdoDatum
,@pVegDatum = @pVegDatum
,@pHelyettesitesTipusId = @pHelyettesitesTipusId
,@pHelyettesitettId = @pHelyettesitettId
,@pHelyettesitoId = @pHelyettesitoId
,@pIsNaplozott = @pIsNaplozott
,@pOsztalyCsoportId = @pOsztalyCsoportId
,@pTantargyId = @pTantargyId
END