42 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Transact-SQL
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Transact-SQL
		
	
	
	
	
	
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 |