DROP FUNCTION IF EXISTS fnGetTanarAltalErtekelhetoCsoportokTantargyak GO CREATE FUNCTION fnGetTanarAltalErtekelhetoCsoportokTantargyak( @pTanarId int ,@pTanevId int ,@OktNevKatTipus int ,@pSzuperOsztalyfonok int ,@pDatum date ) RETURNS TABLE AS RETURN SELECT * FROM (SELECT ocs.ID AS OsztalyCsoportId ,ocs.C_NEV AS Nev ,f.C_TANTARGYID AS TantargyId FROM T_FOGLALKOZAS_OSSZES f INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs ON ocs.ID = f.C_OSZTALYCSOPORTID AND ocs.C_FELADATKATEGORIAID = @OktNevKatTipus AND ocs.C_TANEVID = f.C_TANEVID AND ocs.TOROLT = 'F' INNER JOIN T_TANULOCSOPORT_OSSZES tcs ON ocs.ID = tcs.C_OSZTALYCSOPORTID AND tcs.TOROLT = 'F' WHERE f.TOROLT = 'F' AND @pDatum >= tcs.C_BELEPESDATUM AND (tcs.C_KILEPESDATUM IS NULL OR tcs.C_KILEPESDATUM > @pDatum) AND tcs.C_TANULOID IN (SELECT ID FROM fnGetOsztalyfonokOsztalyanakTanuloi(@pTanarId, @pSzuperOsztalyfonok, @pDatum)) AND f.C_TANEVID = @pTanevId UNION SELECT ocs.ID AS OsztalyCsoportId ,ocs.C_NEV AS Nev ,f.C_TANTARGYID AS TantargyId FROM T_FOGLALKOZAS_OSSZES f INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs ON ocs.ID = f.C_OSZTALYCSOPORTID AND ocs.C_FELADATKATEGORIAID = @OktNevKatTipus AND ocs.TOROLT = 'F' WHERE f.TOROLT = 'F' AND (f.C_TANARID = @pTanarId OR @pSzuperOsztalyfonok = 1) AND ocs.C_TANEVID = @pTanevId) r GO