1135 lines
		
	
	
		
			47 KiB
		
	
	
	
		
			Transact-SQL
		
	
	
	
	
	
			
		
		
	
	
			1135 lines
		
	
	
		
			47 KiB
		
	
	
	
		
			Transact-SQL
		
	
	
	
	
	
SET ANSI_NULLS ON
 | 
						|
GO
 | 
						|
SET QUOTED_IDENTIFIER ON
 | 
						|
GO
 | 
						|
 | 
						|
IF OBJECT_ID('sp_GetOsztalyNaplo') IS NOT NULL BEGIN
 | 
						|
  DROP PROCEDURE [sp_GetOsztalyNaplo] 
 | 
						|
END  
 | 
						|
GO
 | 
						|
 | 
						|
CREATE PROCEDURE [sp_GetOsztalyNaplo]
 | 
						|
  @intezmenyId				INT,
 | 
						|
  @tanevId					INT,
 | 
						|
  @osztalyId				INT,
 | 
						|
  @isSzövegesNaplo			BIT = 0,
 | 
						|
  @iskolaErdekuSzamit		BIT,
 | 
						|
  @fuggolegesTantargyak		BIT
 | 
						|
 | 
						|
AS
 | 
						|
BEGIN
 | 
						|
  SET NOCOUNT ON;
 | 
						|
 | 
						|
  CREATE TABLE  #students (ID INT PRIMARY KEY)
 | 
						|
  INSERT INTO #students
 | 
						|
  SELECT
 | 
						|
	TanuloId 
 | 
						|
  FROM fnGetDokumentumOsztalyokCsoportokTanuloi(@tanevId, @osztalyId, 'T')
 | 
						|
	
 | 
						|
   -- Naplo fooldal
 | 
						|
  CREATE TABLE #osztalycsoportok (OsztalyCsoportId INT PRIMARY KEY) 
 | 
						|
  INSERT INTO #osztalycsoportok (OsztalyCsoportId)
 | 
						|
  SELECT ID FROM fnGetKapcsolodoOsztalycsoportok(@osztalyId)
 | 
						|
 | 
						|
  CREATE TABLE #OsztalyVagyTanoraiCsoport (Id INT)
 | 
						|
  INSERT INTO #OsztalyVagyTanoraiCsoport 
 | 
						|
  SELECT ID FROM fnGetDokumentumOsztalyVagyTanoraiCsoport(@tanevId)
 | 
						|
 | 
						|
  SELECT DISTINCT ocs.C_NEV OsztalyNev, o.C_OSZTALYNAPLOLEIRASA OsztalyMegjegyzes, o.C_OSZTALYFONOKID PartnerID, ofo.C_NYOMTATASINEV Osztalyfonok,
 | 
						|
    i.C_IGAZGATONEVE IntezmenyVezeto, i.C_NEV IntezmenyNeve,
 | 
						|
  	i.C_IRANYITOSZAM IntezmenyIranyitoszam, i.C_VAROS IntezmenyVaros, i.C_CIME IntezmenyCime, i.C_OMKOD IntezmenyOMKod,
 | 
						|
  	FORMAT(o.c_osztalynaplomegnyitasa, 'yyyy. MMMM dd.', 'hu-hu') NaploMegnyitasanakDatuma,
 | 
						|
	ISNULL(FORMAT(o.c_osztalynaplozarasa, 'yyyy. MMMM dd.', 'hu-hu'),'-') NaploZarasanakDatuma 
 | 
						|
  FROM T_OSZTALYCSOPORT_OSSZES ocs 
 | 
						|
  	INNER JOIN T_OSZTALY_OSSZES o ON ocs.ID = o.ID and o.torolt='F'
 | 
						|
  	LEFT JOIN T_FELHASZNALO_OSSZES ofo ON ofo.ID = o.C_OSZTALYFONOKID 
 | 
						|
  	inner JOIN T_INTEZMENYADATOK_OSSZES i on i.C_INTEZMENYID=ocs.C_INTEZMENYID
 | 
						|
  WHERE ocs.ID = @osztalyId 
 | 
						|
 | 
						|
  -- Tanarok
 | 
						|
  SELECT targy.C_NEV TargyNev, tanar.C_NYOMTATASINEV TanarNev
 | 
						|
  FROM T_FELHASZNALO_OSSZES tanar
 | 
						|
  	INNER JOIN T_FOGLALKOZASOK_TANAROK_OSSZES ft ON tanar.ID = ft.C_TANAROKID
 | 
						|
  	INNER JOIN T_FOGLALKOZAS_OSSZES f ON f.ID = ft.C_FOGLALKOZASOKID and f.torolt='F'
 | 
						|
  	INNER JOIN T_TANTARGY_OSSZES targy ON targy.ID = f.C_TANTARGYID and targy.torolt='F' 
 | 
						|
  WHERE tanar.TOROLT = 'F' AND f.TOROLT = 'F' 
 | 
						|
  	AND f.C_OSZTALYCSOPORTID IN (SELECT OsztalyCsoportId FROM #osztalycsoportok) 
 | 
						|
  GROUP BY targy.C_NEV, tanar.C_NYOMTATASINEV
 | 
						|
  ORDER BY targy.C_NEV, tanar.C_NYOMTATASINEV
 | 
						|
 | 
						|
 | 
						|
  -- Orarend
 | 
						|
   EXEC sp_GetOrarendOsztalyonkent @intezmenyId, @tanevID, @osztalyid
 | 
						|
 | 
						|
 | 
						|
  -- Oralatogatasok
 | 
						|
  SELECT  
 | 
						|
	FORMAT(T_ORALATOGATAS_OSSZES.C_DATUM, 'yyyy.MM.dd.')	DATUM
 | 
						|
	,TANITASIORA.C_ORASZAM									ORASZAM
 | 
						|
	,TARGY.C_NEV											TARGYNEV
 | 
						|
	,T_FELHASZNALO_OSSZES.C_NYOMTATASINEV					LATOGATO
 | 
						|
	,T_ORALATOGATAS_OSSZES.C_ORALATOGATOBEOSZTASA			LATOGATOBEOSZTAS
 | 
						|
	,T_ORALATOGATAS_OSSZES.C_MEGJEGYZES						ESZREVETEL
 | 
						|
  FROM T_ORALATOGATAS_OSSZES
 | 
						|
  	INNER JOIN T_FELHASZNALO_OSSZES ON T_FELHASZNALO_OSSZES.ID = T_ORALATOGATAS_OSSZES.C_ERTEKELOID
 | 
						|
  	INNER JOIN (SELECT ID, C_TANTARGYID, C_ORASZAM, C_OSZTALYCSOPORTID FROM T_TANITASIORA_OSSZES ) TANITASIORA ON TANITASIORA.ID = T_ORALATOGATAS_OSSZES.C_MEGTARTOTTORAID
 | 
						|
  	INNER JOIN T_TANTARGY_OSSZES TARGY ON TARGY.ID = TANITASIORA.C_TANTARGYID
 | 
						|
  WHERE 
 | 
						|
	T_ORALATOGATAS_OSSZES.TOROLT='F' 
 | 
						|
	AND T_ORALATOGATAS_OSSZES.c_tanevId=@tanevId
 | 
						|
  	AND C_OSZTALYCSOPORTID IN (SELECT ID FROM fnGetKapcsolodoOsztalycsoportok(@osztalyId))
 | 
						|
  ORDER BY T_ORALATOGATAS_OSSZES.C_DATUM, TANITASIORA.C_ORASZAM
 | 
						|
 | 
						|
  -- Naploellenorzesek
 | 
						|
  SELECT 
 | 
						|
	FORMAT(C_ELLENORZESDATUMA, 'yyyy.MM.dd.')	ELLENORZESDATUMA
 | 
						|
	,ELLENORZO.C_NYOMTATASINEV					ELLENORZOSZEMELY
 | 
						|
	,T_NAPLOELLENORZES_OSSZES.C_ESZREVETEL		ESZREVETEL
 | 
						|
  FROM T_NAPLOELLENORZES_OSSZES
 | 
						|
  	INNER JOIN T_FELHASZNALO_OSSZES ELLENORZO ON ELLENORZO.ID = T_NAPLOELLENORZES_OSSZES.C_ELLENORZOSZEMELYID
 | 
						|
  WHERE 
 | 
						|
	C_OSZTALYID = @osztalyId 
 | 
						|
    AND T_NAPLOELLENORZES_OSSZES.TOROLT = 'F' 
 | 
						|
	AND T_NAPLOELLENORZES_OSSZES.c_tanevId=@tanevId
 | 
						|
 | 
						|
  /* Napló */
 | 
						|
  	DECLARE @datum DATE=GETDATE()
 | 
						|
	CREATE TABLE #OraSorszam (TanitasioraId int, OraSorszam int)
 | 
						|
	INSERT INTO #OraSorszam 
 | 
						|
	EXEC	sp_GetOraSorszamByOsztaly
 | 
						|
		@osztalyCsoportId = @osztalyId,
 | 
						|
		@datum = @datum,
 | 
						|
		@intezmenyId = @intezmenyId,
 | 
						|
		@tanevId = @tanevId
 | 
						|
 | 
						|
  	SELECT 
 | 
						|
		tao.Id						TanitasioraId
 | 
						|
		,tao.C_DATUM				Datum
 | 
						|
		,C_ORASZAM					Oraszam
 | 
						|
		,C_ORATULAJDONOSID			PedagogusId
 | 
						|
		,C_NYOMTATASINEV			PedagogusNev
 | 
						|
		,IIF(C_MEGTARTOTT = 'T', ISNULL(CONVERT(NVARCHAR(MAX), OraSorszam),'-'), '-')			OraSorszam
 | 
						|
		,IIF(C_MEGTARTOTT = 'T', C_TEMA, 'Elmaradt')		Tema
 | 
						|
		,IIF(C_MEGTARTOTT = 'T', ISNULL(CONVERT(NVARCHAR(MAX), OraSorszam),'-') +'.: ' + C_TEMA, 'Elmaradt')	TemaOraSzammal
 | 
						|
		,tao.C_HETNAPJA				HetNapja
 | 
						|
		,C_HETSORSZAMA				HetSorszama
 | 
						|
		,C_MEGTARTOTT				Megtartott
 | 
						|
		,C_TANTARGYID				TantargyId	
 | 
						|
		,IIF(tantargy.C_NEV <> C_NEVNYOMTATVANYBAN AND C_NEVNYOMTATVANYBAN IS NOT NULL, C_NEVNYOMTATVANYBAN + ' (' + tantargy.C_NEV + ')', tantargy.C_NEV)	Tantargynev
 | 
						|
		,C_OSZTALYCSOPORTID			OsztalyCsoportId
 | 
						|
		,C_NAPSORSZAMA				NapSorszama
 | 
						|
	INTO #megtartottOrak
 | 
						|
	FROM T_TANITASIORA_OSSZES tao 
 | 
						|
		INNER JOIN T_FELHASZNALO_OSSZES pedagogus ON pedagogus.Id = tao.C_ORATULAJDONOSID
 | 
						|
		INNER JOIN T_TANTARGY_OSSZES tantargy ON tantargy.Id = tao.C_TANTARGYID
 | 
						|
		LEFT JOIN #OraSorszam oraSorszam ON oraSorszam.TanitasioraId = tao.Id
 | 
						|
	WHERE 
 | 
						|
		C_OSZTALYCSOPORTID IN (SELECT OsztalyCsoportId FROM #osztalycsoportok)
 | 
						|
		AND tao.TOROLT = 'F'
 | 
						|
 | 
						|
	SELECT 
 | 
						|
		nn.C_HETSORSZAMA
 | 
						|
		,MIN(nn.C_NAPDATUMA)
 | 
						|
		,MAX(nn.C_NAPDATUMA) 
 | 
						|
	FROM T_NAPTARINAP_OSSZES nn
 | 
						|
	  INNER JOIN T_TANEV_OSSZES te ON te.ID = nn.C_TANEVID AND te.TOROLT = 'F'
 | 
						|
	WHERE nn.C_NAPDATUMA BETWEEN te.C_ELSOTANITASINAP AND te.C_UTOLSOTANITASINAP
 | 
						|
		AND (nn.C_HETNAPJA BETWEEN 1408 AND 1412 OR nn.C_ORARENDINAP = 'T')
 | 
						|
		AND nn.torolt='F' AND nn.c_intezmenyId=@intezmenyId AND nn.c_tanevId=@tanevId
 | 
						|
	GROUP BY nn.C_HETSORSZAMA
 | 
						|
	ORDER BY MIN(nn.C_NAPDATUMA)
 | 
						|
 | 
						|
	SELECT
 | 
						|
		C_NAPDATUMA			Datum
 | 
						|
		,oraszam			Oraszam
 | 
						|
		,C_HETSORSZAMA		HetSorszama
 | 
						|
	INTO #OsszesOra
 | 
						|
	FROM T_NAPTARINAP_OSSZES
 | 
						|
		CROSS JOIN (VALUES (1),(2),(3),(4),(5),(6),(7),(8),(9),(10),(11),(12)) oraszam(oraszam)
 | 
						|
	WHERE
 | 
						|
		C_TANEVID = @tanevId
 | 
						|
		AND C_ORARENDINAP = 'T'	
 | 
						|
		AND TOROLT = 'F'
 | 
						|
 | 
						|
	IF @isSzövegesNaplo = 0 BEGIN   /* NORMÁL OSZTÁLYNAPLÓ */    
 | 
						|
    DECLARE @selectList nvarchar(MAX),
 | 
						|
      @pivotList nvarchar(MAX)
 | 
						|
	
 | 
						|
	SELECT DISTINCT 
 | 
						|
		tao.C_DATUM		Datum
 | 
						|
		,t.C_NYOMTATASINEV + ' [' + STUFF((
 | 
						|
										SELECT  ', ' + CAST(btao.C_ORASZAM AS VARCHAR(3)) + IIF(tm.C_TIPUS = 1500, '', '(k)')
 | 
						|
										FROM T_TANULOMULASZTAS_OSSZES tm
 | 
						|
											INNER JOIN T_TANITASIORA_OSSZES btao ON btao.ID = tm.C_TANITASIORAKID
 | 
						|
										WHERE 
 | 
						|
											tao.C_DATUM = btao.C_DATUM
 | 
						|
											AND m.C_ORATANULOIID = tm.C_ORATANULOIID
 | 
						|
											AND tm.TOROLT = 'F' 
 | 
						|
											AND tm.c_tanevId=@tanevId
 | 
						|
											AND tm.c_oratanuloiid in (SELECT Id from #students)
 | 
						|
										ORDER BY btao.C_NAPTARINAPID, btao.C_ORASZAM
 | 
						|
										FOR XML PATH(''), TYPE).value('.', 'varchar(max)'),1,3,'') + '] ' + CAST(SUM(IIF(m.C_IGAZOLT = 'T', 1, 0)) AS varchar(2)) + '/' + CAST(SUM(IIF(m.C_IGAZOLT = 'T' OR m.C_TIPUS = 1499, 0, 1)) AS varchar(2)) AS Hianyzas
 | 
						|
	INTO #hianyzasokTMP
 | 
						|
    FROM T_TANITASIORA_OSSZES tao
 | 
						|
      INNER JOIN T_TANULOMULASZTAS_OSSZES m ON m.C_TANITASIORAKID = tao.ID  
 | 
						|
      INNER JOIN #osztalycsoportok cs ON cs.OsztalyCsoportId = tao.C_OSZTALYCSOPORTID
 | 
						|
      INNER JOIN T_FELHASZNALO_OSSZES t ON t.ID = m.C_ORATANULOIID
 | 
						|
    WHERE 
 | 
						|
		m.TOROLT = 'F' 
 | 
						|
		AND m.c_tanevId = @tanevId
 | 
						|
		AND tao.C_OSZTALYCSOPORTID IN (SELECT ID FROM #OsztalyVagyTanoraiCsoport)
 | 
						|
		AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
 | 
						|
    GROUP BY tao.C_DATUM, C_ORATANULOIID, C_NYOMTATASINEV
 | 
						|
 | 
						|
	SELECT 
 | 
						|
		Datum
 | 
						|
		,STUFF((
 | 
						|
          SELECT char(13) + char(10) + Hianyzas
 | 
						|
          FROM #hianyzasokTMP bHianyzasok 
 | 
						|
          WHERE 
 | 
						|
			Hianyzasok.Datum = bHianyzasok.Datum
 | 
						|
          FOR XML PATH(''), TYPE).value('.', 'varchar(max)'),2,1,'') AS Hianyzas 
 | 
						|
	INTO #hianyzasok
 | 
						|
	FROM #hianyzasokTMP Hianyzasok
 | 
						|
 | 
						|
	SELECT DISTINCT
 | 
						|
		NapSorszama
 | 
						|
		,Datum
 | 
						|
		,HetSorszama
 | 
						|
		,HetNapja
 | 
						|
		,Oraszam
 | 
						|
		,STUFF((SELECT DISTINCT 
 | 
						|
					' | ' + CAST(bmto.TantargyNev AS VARCHAR(max)) 
 | 
						|
				FROM #megtartottOrak bmto 
 | 
						|
				WHERE 
 | 
						|
					bmto.Datum = mto.Datum
 | 
						|
					AND bmto.Oraszam = mto.Oraszam
 | 
						|
				FOR XML PATH(''), TYPE)
 | 
						|
			.value('.','NVARCHAR(MAX)'),1,3,'') Tantargy
 | 
						|
	INTO #Orarend
 | 
						|
	FROM #megtartottOrak mto
 | 
						|
 | 
						|
	SELECT DISTINCT
 | 
						|
		Datum
 | 
						|
		,1 Oraszam
 | 
						|
		,TantargyId
 | 
						|
		,STUFF((SELECT DISTINCT 
 | 
						|
					' | ' + CAST(bmto.TemaOraSzammal AS VARCHAR(max)) 
 | 
						|
				FROM #megtartottOrak bmto 
 | 
						|
				WHERE 
 | 
						|
					bmto.Datum = mto.Datum
 | 
						|
					AND bmto.TantargyId = mto.TantargyId
 | 
						|
				FOR XML PATH(''), TYPE)
 | 
						|
			.value('.','NVARCHAR(MAX)'),1,3,'') Tema
 | 
						|
	INTO #1nap1TantargyTobbOra
 | 
						|
	FROM #megtartottOrak mto
 | 
						|
 | 
						|
	DECLARE @tantargyak NVARCHAR(MAX)
 | 
						|
	DECLARE @tantargyakNevvel NVARCHAR(MAX)
 | 
						|
	SELECT	@tantargyakNevvel = ISNULL(@tantargyakNevvel + ', ', '') + '[' + CAST(t.TantargyId AS NVARCHAR(MAX)) + '] AS [' + t.TantargyNev + ']',
 | 
						|
			@tantargyak = ISNULL(@tantargyak + ', ', '') + '[' + CAST(t.TantargyId AS NVARCHAR(MAX)) + ']'
 | 
						|
	FROM (SELECT DISTINCT TantargyId, TantargyNev FROM #megtartottOrak) t
 | 
						|
 | 
						|
	DECLARE @sql NVARCHAR(MAX)
 | 
						|
	SET @sql = '
 | 
						|
	SELECT
 | 
						|
		Datum
 | 
						|
		,Oraszam
 | 
						|
		, ' + @tantargyak +'
 | 
						|
	INTO #naplo
 | 
						|
	FROM #1nap1TantargyTobbOra
 | 
						|
	PIVOT (MAX(Tema) FOR TantargyId IN (' + @tantargyak + ')) piv
 | 
						|
 | 
						|
	SELECT DISTINCT
 | 
						|
		OsszesOra.Datum			C_NAPDATUMA
 | 
						|
		,Hianyzas				Mulasztas
 | 
						|
		,NULL					Megjegyzés
 | 
						|
		,OsszesOra.Oraszam		ORASZAM
 | 
						|
		,Orarend.NapsorSzama	T1ID
 | 
						|
		,Orarend.NapsorSzama	T2ID
 | 
						|
		,Orarend.NapsorSzama	T3ID
 | 
						|
		,Orarend.Tantargy		TANTARGY
 | 
						|
		,OsszesOra.HetSorszama	C_HETSORSZAMA
 | 
						|
		,Orarend.HetNapja		C_HETNAPJA
 | 
						|
		,' + @tantargyakNevvel + '
 | 
						|
	FROM #OsszesOra OsszesOra
 | 
						|
		LEFT JOIN #Orarend Orarend ON Orarend.Datum = OsszesOra.Datum AND Orarend.Oraszam = OsszesOra.Oraszam
 | 
						|
		LEFT JOIN #naplo Naplo ON Naplo.Datum = OsszesOra.Datum AND Naplo.Oraszam = OsszesOra.Oraszam
 | 
						|
		LEFT JOIN #hianyzasok Hianyzasok ON Hianyzasok.Datum = OsszesOra.Datum
 | 
						|
	WHERE 
 | 
						|
		OsszesOra.ORASZAM <=10
 | 
						|
	'
 | 
						|
 | 
						|
	EXEC sp_executesql @sql
 | 
						|
 | 
						|
	DROP TABLE #1nap1TantargyTobbOra
 | 
						|
	DROP TABLE #OsszesOra
 | 
						|
	DROP TABLE #hianyzasokTMP
 | 
						|
	DROP TABLE #hianyzasok
 | 
						|
	DROP TABLE #Orarend
 | 
						|
 | 
						|
  END -- NORMÁL OSZTÁLYNAPLÓ
 | 
						|
 | 
						|
  ELSE BEGIN -- SZÖVEGES OSZTÁLYNAPLÓ
 | 
						|
 | 
						|
	SELECT
 | 
						|
		OsszesOra.Datum								C_NAPDATUMA
 | 
						|
		,FORMAT(OsszesOra.Datum, 'dddd', 'hu-hu')	Napneve
 | 
						|
		,''											C_MEGJEGYZES
 | 
						|
		,nh.C_HETKEZDONAPJA							C_HETKEZDONAPJA
 | 
						|
		,nh.C_HETUTOLSONAPJA						C_HETUTOLSONAPJA
 | 
						|
		,OsszesOra.HetSorszama						C_HETSORSZAMA
 | 
						|
		,OsszesOra.Oraszam							OraSorszam
 | 
						|
		,NapSorszama								Napszam
 | 
						|
		,Tantargynev								Tantargy	--%%%%%%%%%%%%!!!!!!
 | 
						|
		,PedagogusNev								Tanar
 | 
						|
		,Tema										Oraanyaga
 | 
						|
		,OraSorszam									C_ORAEVESSORSZAM
 | 
						|
	INTO #szoveges
 | 
						|
	FROM #OsszesOra OsszesOra
 | 
						|
		LEFT JOIN #megtartottOrak mto ON mto.Datum = OsszesOra.Datum AND OsszesOra.Oraszam = mto.Oraszam
 | 
						|
		INNER JOIN T_NAPTARIHET_OSSZES nh ON OsszesOra.Datum BETWEEN nh.C_HETKEZDONAPJA AND nh.C_HETUTOLSONAPJA AND nh.C_TANEVID = @tanevId and nh.torolt='F' 
 | 
						|
      
 | 
						|
	SELECT DISTINCT c_napdatuma
 | 
						|
			, napneve
 | 
						|
			, c_megjegyzes
 | 
						|
			, c_hetkezdonapja
 | 
						|
			, c_hetutolsonapja
 | 
						|
			, c_hetsorszama
 | 
						|
			, orasorszam
 | 
						|
			, napszam
 | 
						|
			, STUFF((SELECT DISTINCT ' | ' + CAST(bszov.TANTARGY AS VARCHAR(max)) 
 | 
						|
					 FROM #szoveges bszov 
 | 
						|
					 WHERE 
 | 
						|
						 bszov.C_NAPDATUMA=szov.C_NAPDATUMA
 | 
						|
						 and bszov.ORASORSZAM=szov.ORASORSZAM
 | 
						|
						 and bszov.napszam=szov.napszam
 | 
						|
					 FOR XML PATH(''), TYPE)
 | 
						|
					.value('.','NVARCHAR(MAX)'),1,3,'') TANTARGY
 | 
						|
			, STUFF((SELECT DISTINCT ' | ' + CAST(bszov.TANAR AS VARCHAR(max)) 
 | 
						|
					 FROM #szoveges bszov 
 | 
						|
					 WHERE 
 | 
						|
						 bszov.C_NAPDATUMA=szov.C_NAPDATUMA
 | 
						|
						 and bszov.ORASORSZAM=szov.ORASORSZAM
 | 
						|
						 and bszov.napszam=szov.napszam
 | 
						|
					 FOR XML PATH(''), TYPE)
 | 
						|
					.value('.','NVARCHAR(MAX)'),1,3,'') TANAR
 | 
						|
			, STUFF((SELECT DISTINCT ' | ' + CAST(bszov.ORAANYAGA AS VARCHAR(max)) 
 | 
						|
					 FROM #szoveges bszov 
 | 
						|
					 WHERE 
 | 
						|
						 bszov.C_NAPDATUMA=szov.C_NAPDATUMA
 | 
						|
						 and bszov.ORASORSZAM=szov.ORASORSZAM
 | 
						|
						 and bszov.napszam=szov.napszam
 | 
						|
					 FOR XML PATH(''), TYPE)
 | 
						|
					.value('.','NVARCHAR(MAX)'),1,3,'') ORAANYAGA
 | 
						|
			, STUFF((SELECT DISTINCT ' | ' + CAST(bszov.C_ORAEVESSORSZAM AS VARCHAR(max)) 
 | 
						|
					 FROM #szoveges bszov 
 | 
						|
					 WHERE 
 | 
						|
						 bszov.C_NAPDATUMA=szov.C_NAPDATUMA
 | 
						|
						 and bszov.ORASORSZAM=szov.ORASORSZAM
 | 
						|
						 and bszov.napszam=szov.napszam
 | 
						|
					 FOR XML PATH(''), TYPE)
 | 
						|
					.value('.','NVARCHAR(MAX)'),1,3,'') OraEvesSorszama
 | 
						|
	FROM #szoveges szov
 | 
						|
	ORDER BY C_NAPDATUMA, orasorszam
 | 
						|
   
 | 
						|
    /*Hiányzások*/
 | 
						|
    SELECT C_HETSORSZAMA, C_NYOMTATASINEV, 
 | 
						|
      MAX([1]) AS [Hetfo], MAX([2]) AS [Kedd], MAX([3]) AS [Szerda], 
 | 
						|
      MAX([4]) AS [Csutortok], MAX([5]) AS [Pentek], MAX([6]) AS [Szombat] 
 | 
						|
    FROM (
 | 
						|
      SELECT C_HETSORSZAMA, C_NYOMTATASINEV, [0], [1], [2], [3], [4], [5], [6]
 | 
						|
      FROM (
 | 
						|
       SELECT DISTINCT n.C_NAPTARINAPID, DATEPART(dw,n.C_DATUM) AS NAP, t.C_NYOMTATASINEV, n.C_HETSORSZAMA,
 | 
						|
        '[' + STUFF((
 | 
						|
          SELECT  ', ' + CAST(o.C_ORASZAM AS VARCHAR(3)) + IIF(tm.C_TIPUS = 1500, '', '(k)')
 | 
						|
          FROM T_TANULOMULASZTAS_OSSZES tm
 | 
						|
            INNER JOIN T_TANITASIORA_OSSZES o ON o.ID = tm.C_TANITASIORAKID
 | 
						|
            INNER JOIN #osztalycsoportok cs ON cs.OsztalyCsoportId = o.C_OSZTALYCSOPORTID
 | 
						|
          WHERE n.C_NAPTARINAPID = o.C_NAPTARINAPID
 | 
						|
            AND m.C_ORATANULOIID = tm.C_ORATANULOIID
 | 
						|
            AND tm.C_TANEVID = @tanevId
 | 
						|
			and tm.torolt='F' and tm.c_intezmenyId=@intezmenyId and o.c_tanevId=@tanevId
 | 
						|
			and tm.c_oratanuloiid in (SELECT Id from #students)
 | 
						|
          ORDER BY o.C_NAPTARINAPID, o.C_ORASZAM
 | 
						|
          FOR XML PATH(''), TYPE).value('.', 'varchar(max)'),1,2,'') + '] ' + CAST(SUM(IIF(m.C_IGAZOLT = 'T', 1, 0)) AS varchar(2)) + '/' + CAST(SUM(IIF(m.C_IGAZOLT = 'T' OR m.C_TIPUS = 1499, 0, 1)) AS varchar(2)) AS hianyzas
 | 
						|
        FROM T_TANITASIORA_OSSZES n
 | 
						|
          INNER JOIN T_TANULOMULASZTAS_OSSZES m ON m.C_TANITASIORAKID = n.ID  and m.torolt='F' 
 | 
						|
          INNER JOIN #OsztalyVagyTanoraiCsoport cs ON cs.Id = n.C_OSZTALYCSOPORTID
 | 
						|
          INNER JOIN T_FELHASZNALO t ON t.ID = m.C_ORATANULOIID
 | 
						|
        WHERE 
 | 
						|
			n.C_TANEVID = @tanevId 
 | 
						|
			AND m.C_TANEVID = @tanevId 
 | 
						|
			AND m.C_ORATANULOIID IN (SELECT Id from #students)
 | 
						|
			AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
 | 
						|
        GROUP BY n.C_NAPTARINAPID, C_ORATANULOIID, C_NYOMTATASINEV, n.C_HETSORSZAMA, n.C_DATUM) AS SUB
 | 
						|
        PIVOT
 | 
						|
        (
 | 
						|
        MAX(HIANYZAS)
 | 
						|
        FOR NAP IN ([0], [1], [2], [3], [4], [5], [6])
 | 
						|
      ) AS PivotTable
 | 
						|
    ) AS ASD
 | 
						|
    GROUP BY C_HETSORSZAMA, C_NYOMTATASINEV
 | 
						|
    ORDER BY C_HETSORSZAMA  
 | 
						|
  END --SZÖVEGES OSZTÁLYNAPLÓ
 | 
						|
 | 
						|
  /*TANULÓ adatai*/
 | 
						|
	DECLARE @NaploSorszam TABLE (
 | 
						|
		TanuloId INT
 | 
						|
		,Sorszam INT	
 | 
						|
		)
 | 
						|
 | 
						|
	INSERT INTO @NaploSorszam
 | 
						|
	EXEC [sp_GetDokumentumTanuloNaploSorszam]
 | 
						|
		@osztalyId = @osztalyId
 | 
						|
 | 
						|
	SELECT DISTINCT 
 | 
						|
		tanuloID
 | 
						|
		, sorszam
 | 
						|
		, torzslapSzam
 | 
						|
		, oktAzon
 | 
						|
		, tajSzam
 | 
						|
		, anyjaNeve
 | 
						|
		, szulHely
 | 
						|
		, CONVERT(NVARCHAR(100),DATEPART(YEAR,szulIdo))+'. '+CONVERT(NVARCHAR(100)
 | 
						|
		, datepart(month,szulIdo))+'. '+convert(nvarchar(100)
 | 
						|
		, datepart(day,szulIdo))+'.' SzulIdo
 | 
						|
		, gondviselok
 | 
						|
		, IIF(socAdat = '', '', 
 | 
						|
			 LEFT(socAdat, len(socAdat)- 1)) socAdat
 | 
						|
		, kepzes
 | 
						|
		, tanuloNeve
 | 
						|
		, allampolgarsaga
 | 
						|
		, diakIgazolvanySzam
 | 
						|
		, kilepesDatum
 | 
						|
		, beirasiNaploSorszam
 | 
						|
  FROM (
 | 
						|
  SELECT  
 | 
						|
	t.ID AS tanuloID
 | 
						|
	, naploSorszam.Sorszam as sorszam
 | 
						|
	, f.C_NYILVANTARTASISZAM as torzslapSzam
 | 
						|
	,f.C_OKTATASIAZONOSITO as oktAzon
 | 
						|
	, f.C_TAJSZAM as tajSzam
 | 
						|
	, f.C_ANYJANEVE as anyjaNeve, 
 | 
						|
    f.C_SZULETESIHELY  AS szulHely
 | 
						|
	,f.C_SZULETESIDATUM as szulIdo
 | 
						|
	,IIF(t.C_MAGANTANULO = 'T', 'Magántanuló (eü. ok), ', '') +
 | 
						|
    IIF(t.C_JOGVISZONYATSZUNETELTETO = 'T', 'Jogviszony szüneteltetve, ', '') + 
 | 
						|
    IIF(t.C_SZAKMAIGYAKORLATON = 'T', 'Szakmai gyakorlat, ', '') + 
 | 
						|
    IIF(t.C_SZOCIALISTAMOGATAS = 'T', 'Szociális támogatás, ', '') AS socAdat,
 | 
						|
    tt.C_NEV as kepzes,
 | 
						|
    STUFF((
 | 
						|
    SELECT  char(13) + char(10) + gv.C_NEV
 | 
						|
      FROM T_GONDVISELO_OSSZES gv
 | 
						|
      WHERE  gv.C_TANULOID = s.ID
 | 
						|
        AND gv.TOROLT = 'F'
 | 
						|
      FOR XML PATH(''), TYPE).value('.', 'nvarchar(4000)'),1,2,'') AS gondviselok,
 | 
						|
    f.C_NYOMTATASINEV as tanuloNeve,
 | 
						|
	d.C_NAME allampolgarsaga,
 | 
						|
	t.C_DIAKIGAZOLVANYSZAM diakIgazolvanySzam,
 | 
						|
	MAX(cs.C_KILEPESDATUM) kilepesDatum,
 | 
						|
	t.C_BEIRASINAPLOSORSZAM	beirasiNaploSorszam
 | 
						|
  FROM T_TANULO_OSSZES t
 | 
						|
    INNER JOIN #students s ON s.ID = t.ID
 | 
						|
	INNER JOIN @NaploSorszam naploSorszam on naploSorszam.TanuloId=s.ID
 | 
						|
    INNER JOIN T_TANTERV_OSSZES tt ON tt.ID = t.C_TANTERVID
 | 
						|
    INNER JOIN T_FELHASZNALO_OSSZES f ON f.ID = t.ID
 | 
						|
    INNER JOIN T_TANULOCSOPORT_OSSZES cs ON s.ID = cs.C_TANULOID AND cs.C_OSZTALYCSOPORTID = @osztalyId
 | 
						|
	INNER JOIN T_DICTIONARYITEMBASE_OSSZES d on d.id=f.C_ALLAMPOLGARSAGA AND d.C_TANEVID = f.C_TANEVID AND d.C_INTEZMENYID = f.C_INTEZMENYID
 | 
						|
  WHERE t.TOROLT='F' 
 | 
						|
  GROUP BY 
 | 
						|
	s.ID, t.ID, naploSorszam.Sorszam, f.C_NYILVANTARTASISZAM, f.C_OKTATASIAZONOSITO, f.C_TAJSZAM, f.C_ANYJANEVE, 
 | 
						|
    f.C_SZULETESIHELY, f.C_SZULETESIDATUM, t.C_MAGANTANULO, t.C_JOGVISZONYATSZUNETELTETO, t.C_SZAKMAIGYAKORLATON, 
 | 
						|
	t.C_SZOCIALISTAMOGATAS, tt.C_NEV, f.C_NYOMTATASINEV, d.C_NAME, t.C_DIAKIGAZOLVANYSZAM, t.C_BEIRASINAPLOSORSZAM  
 | 
						|
  ) tbl
 | 
						|
  ORDER BY tanuloNeve
 | 
						|
 | 
						|
  /*TANULÓ elérhetőségei */
 | 
						|
	 SELECT DISTINCT 
 | 
						|
		tanulo.Id tanuloID
 | 
						|
		, cimTipus
 | 
						|
		, cim.OsszetettCim cim
 | 
						|
		, telefon.Telefonszam
 | 
						|
		, email.Email
 | 
						|
		, cim.ct 
 | 
						|
	FROM #students Tanulo
 | 
						|
	LEFT JOIN (SELECT 
 | 
						|
					c.C_FELHASZNALOID Tanulo
 | 
						|
					, c.C_IRANYITOSZAM+', '+c.C_VAROS+', '+C_KOZTERULET+' '+kozteruletJellege.C_NAME+' '+C_HAZSZAM OsszetettCim
 | 
						|
					, cimTipus.C_NAME cimTipus
 | 
						|
					, cimTipus.Id ct 
 | 
						|
				FROM T_CIM_OSSZES c
 | 
						|
					INNER JOIN (SELECT DISTINCT ID, C_NAME FROM T_DICTIONARYITEMBASE_OSSZES d) kozteruletJellege ON kozteruletJellege.Id=c.c_kozteruletjellege
 | 
						|
					INNER JOIN (SELECT DISTINCT ID, C_NAME FROM T_DICTIONARYITEMBASE_OSSZES d) cimTipus ON cimTipus.Id=c.C_CIMTIPUSA
 | 
						|
				WHERE c.TOROLT='F' AND c.C_GONDVISELOID IS NULL) cim ON cim.Tanulo=Tanulo.Id
 | 
						|
	LEFT JOIN (SELECT 
 | 
						|
					C_FELHASZNALOID Tanulo
 | 
						|
					, C_TELEFONSZAM Telefonszam 
 | 
						|
				FROM T_TELEFON_OSSZES 
 | 
						|
				WHERE TOROLT='F' 
 | 
						|
				AND C_ALAPERTELMEZETT='T') telefon on telefon.Tanulo=Tanulo.Id
 | 
						|
	LEFT JOIN (SELECT C_FELHASZNALOID Tanulo
 | 
						|
						, C_EMAILCIM Email 
 | 
						|
				FROM T_EMAIL_OSSZES 
 | 
						|
				WHERE Torolt='F' 
 | 
						|
				AND C_ALAPERTELMEZETT='T') email ON email.Tanulo=Tanulo.Id
 | 
						|
 | 
						|
 | 
						|
  /* TANULÓ mentesség */
 | 
						|
	SELECT s.ID tanuloId 
 | 
						|
			,ROW_NUMBER() OVER(PARTITION BY s.ID ORDER BY s.ID) sorszam
 | 
						|
			, mentesseg.tantargyNev
 | 
						|
			, mentesseg.mentessegOka
 | 
						|
			, ISNULL(IIF(mentesseg = '', ''
 | 
						|
			, LEFT(mentesseg, LEN(mentesseg)- 1)),' ') mentesseg 
 | 
						|
	FROM #students s
 | 
						|
	LEFT JOIN  (SELECT DISTINCT 
 | 
						|
								mentesseg.C_TANULOID tanuloId
 | 
						|
								, IIF(t.C_NEV <> C_NEVNYOMTATVANYBAN AND C_NEVNYOMTATVANYBAN IS NOT NULL, C_NEVNYOMTATVANYBAN + ' (' + t.C_NEV + ')', t.C_NEV) tantargyNev
 | 
						|
								, mentesseg.C_MENTESSEGOKA mentessegOka
 | 
						|
								, IIF(mentesseg.C_ERTEKELESMENTESITES = 'T', 'Értékelésmentesség, ', '') + IIF(mentesseg.C_ORAMENTESITES = 'T', 'Óramentesség, ', '') as mentesseg 
 | 
						|
				FROM T_TANULOMENTESSEG_OSSZES mentesseg
 | 
						|
					INNER JOIN T_TANTARGY_OSSZES t on t.ID=mentesseg.C_TANTARGYID
 | 
						|
				WHERE C_TANULOID IN (SELECT ID FROM #students) 
 | 
						|
						AND mentesseg.TOROLT='F' 
 | 
						|
						AND mentesseg.C_TANEVID=@tanevId
 | 
						|
				) mentesseg ON s.ID=mentesseg.TANULOID
 | 
						|
 | 
						|
  /* TANULÓ határozatok */  
 | 
						|
    SELECT 
 | 
						|
		s.ID as tanuloID
 | 
						|
		, ROW_NUMBER() OVER(PARTITION BY s.ID ORDER BY s.ID) AS sorszam
 | 
						|
		, FORMAT(Datum, 'd', 'hu-hu') as datum
 | 
						|
		, d.C_NAME as tipus
 | 
						|
		, Tartalom as tartalom
 | 
						|
		, FeljegyzoNeve as tanar 
 | 
						|
  FROM #students s 
 | 
						|
    LEFT JOIN fnGetDokumentumTanulokFeljegyzesei(@tanevId, @osztalyId) feljegyzes ON feljegyzes.TanuloId = s.ID
 | 
						|
    LEFT JOIN T_DICTIONARYITEMBASE_OSSZES d ON d.ID = Tipusa  AND d.C_TANEVID = @tanevId
 | 
						|
  WHERE 
 | 
						|
	Tipusa IN (1543, 1544, 1547, 1548, 1549, 1550, 1551, 1552, 1553)
 | 
						|
 | 
						|
  /* TANULÓ feljegyzései */
 | 
						|
    SELECT 
 | 
						|
		s.ID as tanuloID
 | 
						|
		, ROW_NUMBER() OVER(PARTITION BY s.ID ORDER BY s.ID) AS sorszam
 | 
						|
		, FORMAT(Datum, 'd', 'hu-hu') as datum
 | 
						|
		, d.C_NAME as tipus
 | 
						|
		, Tartalom as tartalom
 | 
						|
		, FeljegyzoNeve as tanar 
 | 
						|
  FROM #students s 
 | 
						|
    LEFT JOIN fnGetDokumentumTanulokFeljegyzesei(@tanevId, @osztalyId) feljegyzes ON feljegyzes.TanuloId = s.ID
 | 
						|
    LEFT JOIN T_DICTIONARYITEMBASE_OSSZES d ON d.ID = Tipusa  AND d.C_TANEVID = @tanevId 
 | 
						|
  WHERE 
 | 
						|
	Tipusa NOT IN (1534, 1543, 1544, 1547, 1548, 1549, 1550, 1551, 1552, 1553)
 | 
						|
 | 
						|
  /* TANULO mulasztása */
 | 
						|
DECLARE @Mulasztasok TABLE ( IgazoltE nvarchar(1), Tanulo int, Tipus int)
 | 
						|
 | 
						|
--Félév kezdete
 | 
						|
DECLARE @FelevVege DATE
 | 
						|
SET @FelevVege=		(select top 1 tr.C_DATUM from t_tanevrendje_osszes tr  where tr.c_naptipusa=1400 and c_tanevid=@tanevId and Torolt='F')
 | 
						|
 | 
						|
--hiányzás	
 | 
						|
 | 
						|
--igazolt
 | 
						|
INSERT INTO @Mulasztasok
 | 
						|
SELECT 'T',  * FROM #students
 | 
						|
		CROSS JOIN (SELECT DISTINCT Id FROM T_DICTIONARYITEMBASE_OSSZES WHERE C_TANEVID = @tanevId AND C_TYPE LIKE 'igazolastipus' AND (@iskolaErdekuSzamit = 1 OR Id <> 1533) ) Tipus (Tipus)
 | 
						|
 | 
						|
SELECT Mulasztas.tanuloid, Mulasztas.tipus, Mulasztas.[09.], Mulasztas.[10.], Mulasztas.[11.], Mulasztas.[12.],
 | 
						|
		Mulasztas.[01.], Mulasztas.[02.], Mulasztas.[03.], Mulasztas.[04.], Mulasztas.[05.], Mulasztas.[06.],
 | 
						|
		mulasztas.felev felev, isnull(Mulasztas.osszesen,0) Osszesen, mulasztas.Rendez FROM 
 | 
						|
(
 | 
						|
	select m.Tanulo tanuloid, '-'+d.c_name tipus, 		 
 | 
						|
			isnull(p.[9],0) '09.', isnull(p.[10],0) '10.', isnull(p.[11],0) '11.', isnull(p.[12],0) '12.', 
 | 
						|
			isnull(p.[1],0) '01.', isnull(p.[2],0) '02.', isnull(p.[3],0) '03.', isnull(p.[4],0) '04.', isnull(p.[5],0) '05.', isnull(p.[6],0) '06.',
 | 
						|
			isnull(Felev,0) 'felev', [9]+[10]+[11]+[12]+[1]+[2]+[3]+[4]+[5]+[6] 'osszesen', d.id Rendez
 | 
						|
	from @Mulasztasok m
 | 
						|
	left join  	(select * from (select tm.id id, tm.c_igazolt IgazoltE, tm.c_oratanuloiid Tanulo, tm.c_igazolastipusa Tipus, datepart(month,tao.c_datum) Honap from t_tanulomulasztas_osszes tm
 | 
						|
					inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport)
 | 
						|
				where tm.c_tanevId=@tanevId and tm.c_igazolt='T' and tm.c_tipus=1500 and tm.torolt='F' AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533))a
 | 
						|
				pivot (count(id) for Honap in ([9], [10], [11], [12], [1], [2], [3], [4], [5], [6]))piv
 | 
						|
				)p on p.tanulo=m.Tanulo and p.igazoltE=m.IgazoltE and p.Tipus=m.Tipus
 | 
						|
	left join (select distinct id, c_name from t_dictionaryitembase_osszes)d on d.id=m.Tipus
 | 
						|
	left join (select count(tm.id) Felev, tm.c_igazolt IgazoltE, tm.c_oratanuloiid Tanulo, tm.c_igazolastipusa Tipus from t_tanulomulasztas_osszes tm
 | 
						|
					inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport) and tao.c_datum<=@FelevVege
 | 
						|
				where tm.c_tanevId=@tanevId and tm.c_igazolt='T' and tm.c_tipus=1500 and tm.torolt='F' AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
 | 
						|
				group by tm.c_igazolt, tm.c_oratanuloiid, tm.c_igazolastipusa
 | 
						|
				)felev on felev.tanulo=m.Tanulo and felev.igazoltE=m.IgazoltE and felev.Tipus=m.Tipus
 | 
						|
 | 
						|
	union
 | 
						|
 | 
						|
	select s.id, 'igazolt',  
 | 
						|
			isnull(ni.[9],0) '09.', isnull(ni.[10],0) '10.', isnull(ni.[11],0) '11.', isnull(ni.[12],0) '12.', 
 | 
						|
			isnull(ni.[1],0) '01.', isnull(ni.[2],0) '02.', isnull(ni.[3],0) '03.', isnull(ni.[4],0) '04.', isnull(ni.[5],0) '05.', isnull(ni.[6],0) '06.',
 | 
						|
			isnull(Felev,0) 'felev', [9]+[10]+[11]+[12]+[1]+[2]+[3]+[4]+[5]+[6] 'osszesen', 2 Rendez
 | 
						|
	from #students s
 | 
						|
		left join (	select * from (select  tm.id id, tm.c_igazolt IgazoltE, tm.c_oratanuloiid Tanulo, 'igazolatlan' tipus, datepart(month,tao.c_datum) Honap  from t_tanulomulasztas_osszes tm 
 | 
						|
						inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport)
 | 
						|
					where tm.c_tanevId=@tanevId and tm.c_igazolt='T' and tm.c_tipus=1500 and tm.torolt='F' AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533))a
 | 
						|
					pivot (count(id) for Honap in ([9], [10], [11], [12], [1], [2], [3], [4], [5], [6]))piv )ni on ni.Tanulo=s.Id
 | 
						|
		left join (select count(tm.id) Felev, tm.c_oratanuloiid Tanulo from t_tanulomulasztas_osszes tm
 | 
						|
					inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport) and tao.c_datum<=@FelevVege
 | 
						|
				where tm.c_tanevId=@tanevId and tm.c_igazolt='T' and tm.c_tipus=1500 and tm.torolt='F' AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
 | 
						|
				group by tm.c_oratanuloiid
 | 
						|
				)felev on felev.tanulo=s.id
 | 
						|
 | 
						|
	union
 | 
						|
 | 
						|
	--igazolatlan
 | 
						|
	select s.id, 'igazolatlan',  
 | 
						|
			isnull(ni.[9],0) '09.', isnull(ni.[10],0) '10.', isnull(ni.[11],0) '11.', isnull(ni.[12],0) '12.', 
 | 
						|
			isnull(ni.[1],0) '01.', isnull(ni.[2],0) '02.', isnull(ni.[3],0) '03.', isnull(ni.[4],0) '04.', isnull(ni.[5],0) '05.', isnull(ni.[6],0) '06.',
 | 
						|
			isnull(Felev,0) 'felev', [9]+[10]+[11]+[12]+[1]+[2]+[3]+[4]+[5]+[6] 'osszesen', 4999 Rendez
 | 
						|
	from #students s
 | 
						|
		left join (	select * from (select  tm.id id, tm.c_igazolt IgazoltE, tm.c_oratanuloiid Tanulo, 'igazolatlan' tipus, datepart(month,tao.c_datum) Honap  from t_tanulomulasztas_osszes tm 
 | 
						|
						inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport)
 | 
						|
					where tm.c_tanevId=@tanevId and tm.c_igazolt='F' and tm.c_tipus=1500 and tm.torolt='F')a
 | 
						|
					pivot (count(id) for Honap in ([9], [10], [11], [12], [1], [2], [3], [4], [5], [6]))piv )ni on ni.Tanulo=s.Id
 | 
						|
		left join (select count(tm.id) Felev, tm.c_oratanuloiid Tanulo from t_tanulomulasztas_osszes tm
 | 
						|
					inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport) and tao.c_datum<=@FelevVege
 | 
						|
				where tm.c_tanevId=@tanevId and tm.c_igazolt='F' and tm.c_tipus=1500 and tm.torolt='F' AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
 | 
						|
				group by tm.c_oratanuloiid
 | 
						|
				)felev on felev.tanulo=s.id
 | 
						|
	
 | 
						|
	union 
 | 
						|
 | 
						|
	--Összes
 | 
						|
	select s.id, 'mulasztás',  
 | 
						|
			isnull(ni.[9],0) '09.', isnull(ni.[10],0) '10.', isnull(ni.[11],0) '11.', isnull(ni.[12],0) '12.', 
 | 
						|
			isnull(ni.[1],0) '01.', isnull(ni.[2],0) '02.', isnull(ni.[3],0) '03.', isnull(ni.[4],0) '04.', isnull(ni.[5],0) '05.', isnull(ni.[6],0) '06.',
 | 
						|
			isnull(Felev,0) 'felev', [9]+[10]+[11]+[12]+[1]+[2]+[3]+[4]+[5]+[6] 'osszesen', 1 Rendez
 | 
						|
	from #students s
 | 
						|
		left join (	select * from (select  tm.id id, tm.c_oratanuloiid Tanulo, 'Összes' tipus, datepart(month,tao.c_datum) Honap  from t_tanulomulasztas_osszes tm 
 | 
						|
						inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport)
 | 
						|
					where tm.c_tanevId=@tanevId and tm.c_tipus=1500 and tm.C_IGAZOLT in ('F', 'T') and  tm.torolt='F' AND (@iskolaErdekuSzamit = 1 OR (C_IGAZOLASTIPUSA <> 1533 OR C_IGAZOLASTIPUSA IS NULL)))a
 | 
						|
					pivot (count(id) for Honap in ([9], [10], [11], [12], [1], [2], [3], [4], [5], [6]))piv )ni on ni.Tanulo=s.Id
 | 
						|
		left join (select count(tm.id) Felev, tm.c_oratanuloiid Tanulo from t_tanulomulasztas_osszes tm
 | 
						|
					inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport) and tao.c_datum<=@FelevVege
 | 
						|
				where tm.c_tanevId=@tanevId and tm.c_tipus=1500 AND tm.C_IGAZOLT IN ('F', 'T') and tm.torolt='F' AND (@iskolaErdekuSzamit = 1 OR (C_IGAZOLASTIPUSA <> 1533 OR C_IGAZOLASTIPUSA IS NULL))
 | 
						|
				group by tm.c_oratanuloiid
 | 
						|
				)felev on felev.tanulo=s.id
 | 
						|
--késés
 | 
						|
	union
 | 
						|
 | 
						|
	select s.id, 'késés (p)',  
 | 
						|
			isnull(ni.[9],0) '09.', isnull(ni.[10],0) '10.', isnull(ni.[11],0) '11.', isnull(ni.[12],0) '12.', 
 | 
						|
			isnull(ni.[1],0) '01.', isnull(ni.[2],0) '02.', isnull(ni.[3],0) '03.', isnull(ni.[4],0) '04.', isnull(ni.[5],0) '05.', isnull(ni.[6],0) '06.',
 | 
						|
			isnull(Felev,0) 'felev', 			
 | 
						|
			isnull(ni.[9],0)+isnull(ni.[10],0)+isnull(ni.[11],0)+isnull(ni.[12],0)+ isnull(ni.[1],0)+
 | 
						|
			isnull(ni.[2],0)+isnull(ni.[3],0)+isnull(ni.[4],0)+isnull(ni.[5],0)+isnull(ni.[6],0)			
 | 
						|
			'osszesen', 5000 Rendez
 | 
						|
	from #students s
 | 
						|
		left join (	select * from (select  tm.c_kesespercben perc, tm.c_igazolt IgazoltE, tm.c_oratanuloiid Tanulo, 'késés' tipus, datepart(month,tao.c_datum) Honap  from t_tanulomulasztas_osszes tm 
 | 
						|
						inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport)
 | 
						|
					where tm.c_tanevId=@tanevId and tm.c_tipus=1499 and tm.torolt='F' AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533))a
 | 
						|
					pivot (sum(perc) for Honap in ([9], [10], [11], [12], [1], [2], [3], [4], [5], [6]))piv )ni on ni.Tanulo=s.Id
 | 
						|
		left join (select sum(tm.c_kesespercben) Felev, tm.c_oratanuloiid Tanulo from t_tanulomulasztas_osszes tm
 | 
						|
					inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport) and tao.c_datum<=@FelevVege
 | 
						|
				where tm.c_tanevId=@tanevId and tm.c_tipus=1499 and tm.torolt='F' AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
 | 
						|
				group by tm.c_oratanuloiid
 | 
						|
				)felev on felev.tanulo=s.id
 | 
						|
 | 
						|
	union 
 | 
						|
 | 
						|
	--igazolt
 | 
						|
	select s.id, '* igazolt (p)',  
 | 
						|
			isnull(ni.[9],0) '09.', isnull(ni.[10],0) '10.', isnull(ni.[11],0) '11.', isnull(ni.[12],0) '12.', 
 | 
						|
			isnull(ni.[1],0) '01.', isnull(ni.[2],0) '02.', isnull(ni.[3],0) '03.', isnull(ni.[4],0) '04.', isnull(ni.[5],0) '05.', isnull(ni.[6],0) '06.',
 | 
						|
			isnull(Felev,0) 'felev', 
 | 
						|
			isnull(ni.[9],0)+isnull(ni.[10],0)+isnull(ni.[11],0)+isnull(ni.[12],0)+ isnull(ni.[1],0)+
 | 
						|
			isnull(ni.[2],0)+isnull(ni.[3],0)+isnull(ni.[4],0)+isnull(ni.[5],0)+isnull(ni.[6],0)'osszesen', 5001 Rendez
 | 
						|
	from #students s
 | 
						|
		left join (	select * from (select  tm.c_kesespercben perc, tm.c_igazolt IgazoltE, tm.c_oratanuloiid Tanulo, 'késés' tipus, datepart(month,tao.c_datum) Honap  from t_tanulomulasztas_osszes tm 
 | 
						|
						inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport)
 | 
						|
					where tm.c_tanevId=@tanevId and tm.c_tipus=1499 and tm.c_igazolt='T' and tm.torolt='F' AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533))a
 | 
						|
					pivot (sum(perc) for Honap in ([9], [10], [11], [12], [1], [2], [3], [4], [5], [6]))piv )ni on ni.Tanulo=s.Id
 | 
						|
		left join (select sum(tm.c_kesespercben) Felev, tm.c_oratanuloiid Tanulo from t_tanulomulasztas_osszes tm
 | 
						|
					inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport) and tao.c_datum<=@FelevVege
 | 
						|
				where tm.c_tanevId=@tanevId and tm.c_tipus=1499 and tm.c_igazolt='T' and tm.torolt='F' AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
 | 
						|
				group by tm.c_oratanuloiid
 | 
						|
				)felev on felev.tanulo=s.id
 | 
						|
 | 
						|
	union 
 | 
						|
 | 
						|
	--igazolatlan
 | 
						|
	select s.id, '* igazolatlan (p)',  
 | 
						|
			isnull(ni.[9],0) '09.', isnull(ni.[10],0) '10.', isnull(ni.[11],0) '11.', isnull(ni.[12],0) '12.', 
 | 
						|
			isnull(ni.[1],0) '01.', isnull(ni.[2],0) '02.', isnull(ni.[3],0) '03.', isnull(ni.[4],0) '04.', isnull(ni.[5],0) '05.', isnull(ni.[6],0) '06.',
 | 
						|
			isnull(Felev,0) 'felev', 
 | 
						|
			isnull(ni.[9],0)+isnull(ni.[10],0)+isnull(ni.[11],0)+isnull(ni.[12],0)+ isnull(ni.[1],0)+
 | 
						|
			isnull(ni.[2],0)+isnull(ni.[3],0)+isnull(ni.[4],0)+isnull(ni.[5],0)+isnull(ni.[6],0) 'osszesen', 5002 Rendez
 | 
						|
	from #students s
 | 
						|
		left join (	select * from (select  tm.c_kesespercben perc, tm.c_igazolt IgazoltE, tm.c_oratanuloiid Tanulo, 'késés' tipus, datepart(month,tao.c_datum) Honap  from t_tanulomulasztas_osszes tm 
 | 
						|
						inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport)
 | 
						|
					where tm.c_tanevId=@tanevId and tm.c_tipus=1499 and tm.c_igazolt='F' and tm.torolt='F')a
 | 
						|
					pivot (sum(perc) for Honap in ([9], [10], [11], [12], [1], [2], [3], [4], [5], [6]))piv )ni on ni.Tanulo=s.Id
 | 
						|
		left join (select sum(tm.c_kesespercben) Felev, tm.c_oratanuloiid Tanulo from t_tanulomulasztas tm
 | 
						|
					inner join t_tanitasiora_osszes tao on tm.c_tanitasiorakid=tao.id and tao.c_osztalycsoportid in (SELECT ID FROM #OsztalyVagyTanoraiCsoport) and tao.c_datum<=@FelevVege
 | 
						|
				where tm.c_tanevId=@tanevId and tm.c_tipus=1499 and tm.c_igazolt='F' and tm.torolt='F'
 | 
						|
				group by tm.c_oratanuloiid
 | 
						|
				)felev on felev.tanulo=s.id
 | 
						|
)Mulasztas
 | 
						|
order by Rendez
 | 
						|
 | 
						|
 | 
						|
declare @gondviselok table (Id int)
 | 
						|
insert into @gondviselok
 | 
						|
select g.ID from #students s
 | 
						|
	left join T_GONDVISELO_OSSZES g on g.C_TANULOID=s.id
 | 
						|
 | 
						|
  /*gondviselő elérhetőségei */
 | 
						|
SELECT 
 | 
						|
	s.Id Id
 | 
						|
	, g.c_nev C_NEV
 | 
						|
	, cim.cimTipus C_CIMTIPUSA
 | 
						|
	, cim.OsszetettCim+' ('+cim.cimTipus+')' C_OSSZETETTCIM
 | 
						|
	, telefon.Telefonszam C_TELEFONSZAM
 | 
						|
	, email.Email C_EMAILCIM
 | 
						|
FROM #students s
 | 
						|
	LEFT JOIN T_GONDVISELO_OSSZES g on g.c_tanuloid=s.id 
 | 
						|
	LEFT JOIN (SELECT 
 | 
						|
					c.c_gondviseloid Gondviselo
 | 
						|
					, c.C_IRANYITOSZAM+', '+c.C_VAROS+', '+c_kozterulet+' '+kozteruletJellege.c_name+' '+c_hazszam OsszetettCim
 | 
						|
					, cimTipus.c_name cimTipus 
 | 
						|
				FROM T_CIM_OSSZES c
 | 
						|
					INNER JOIN (SELECT DISTINCT ID, C_NAME FROM T_DICTIONARYITEMBASE_OSSZES d) kozteruletJellege ON kozteruletJellege.Id=c.C_KOZTERULETJELLEGE
 | 
						|
					INNER JOIN (SELECT DISTINCT ID, C_NAME FROM T_DICTIONARYITEMBASE_OSSZES d) cimTipus ON cimTipus.Id=c.c_cimtipusa
 | 
						|
				WHERE  c.TOROLT='F' and c.C_GONDVISELOID IN (SELECT ID FROM @gondviselok)) cim ON cim.Gondviselo=g.Id
 | 
						|
	LEFT JOIN (SELECT C_GONDVISELOID Gondviselo, C_TELEFONSZAM Telefonszam FROM T_TELEFON_OSSZES WHERE TOROLT='F' ) telefon ON telefon.Gondviselo=g.Id
 | 
						|
	LEFT JOIN (SELECT C_GONDVISELOID Gondviselo, C_EMAILCIM Email from T_EMAIL_OSSZES where TOROLT='F') email ON email.Gondviselo=g.Id
 | 
						|
 | 
						|
 | 
						|
  /*TANULÓ osztályzatai*/
 | 
						|
   IF @fuggolegesTantargyak = 1
 | 
						|
   BEGIN
 | 
						|
	  SET @pivotList = null;
 | 
						|
	  SET @selectList = null;
 | 
						|
	  SET @sql = null;
 | 
						|
	  DECLARE @columnList nvarchar(max);
 | 
						|
 | 
						|
	  SELECT 
 | 
						|
		@pivotList  = ISNULL(@pivotList  + ', ', '') + '[' + CAST(t.TantargyId AS varchar(6)) + ']',
 | 
						|
		@selectList = ISNULL(@selectList + ', ', '') + '[' + CAST(t.TantargyId AS varchar(6)) + '] AS [' + t.TantargyNev + ']',
 | 
						|
		@columnList = ISNULL(@columnList + ', ', '') + '[' + CAST(t.TantargyId AS varchar(6)) + '] nvarchar(250) '
 | 
						|
	  FROM (
 | 
						|
		SELECT DISTINCT TantargyId, TantargyNev FROM #megtartottOrak) t
 | 
						|
 | 
						|
	  SET @sql = '
 | 
						|
	  DECLARE @masodikFelev datetime  
 | 
						|
	  SELECT TOP 1 @masodikFelev = DATEADD(d, 1, C_DATUM) 
 | 
						|
	  FROM T_TANEVRENDJE_OSSZES 
 | 
						|
	  WHERE T_TANEVRENDJE_OSSZES.TOROLT=''F'' AND C_NAPTIPUSA= 1400 --Első félév vége
 | 
						|
	  and torolt=''F'' and c_intezmenyId=@intezmenyId 
 | 
						|
 | 
						|
	  DECLARE @idoszak TABLE (
 | 
						|
		id int primary key, 
 | 
						|
		period varchar(10), 
 | 
						|
		startdate datetime, 
 | 
						|
		enddate datetime
 | 
						|
	  )
 | 
						|
 | 
						|
	  INSERT INTO @idoszak (
 | 
						|
		 id
 | 
						|
		,period
 | 
						|
		,startdate
 | 
						|
		,enddate
 | 
						|
	  ) SELECT 
 | 
						|
		ROW_NUMBER() OVER(ORDER BY (SELECT 1))  AS id
 | 
						|
		,IIF(MONTH(n.C_NAPDATUMA) <> 1, CAST(MONTH(n.C_NAPDATUMA) AS varchar(3)), ''1/I'') AS period
 | 
						|
		,DATEFROMPARTS ( YEAR(n.C_NAPDATUMA), MONTH(n.C_NAPDATUMA), 1 ) AS startdate
 | 
						|
		,IIF(MONTH(n.C_NAPDATUMA) = 1,
 | 
						|
		  @masodikFelev,
 | 
						|
		  DATEADD(m, 1, DATEFROMPARTS ( YEAR(n.C_NAPDATUMA), MONTH(n.C_NAPDATUMA), 1 ))
 | 
						|
		) AS enddate
 | 
						|
	  FROM T_NAPTARINAP_OSSZES n
 | 
						|
		INNER JOIN T_TANEV_OSSZES te ON te.ID = n.C_TANEVID
 | 
						|
	  WHERE 
 | 
						|
		MONTH(n.C_NAPDATUMA) IN (1, 9, 10, 11, 12)
 | 
						|
		AND n.C_TANEVID = @tanevId
 | 
						|
	  GROUP BY YEAR(n.C_NAPDATUMA), MONTH(n.C_NAPDATUMA)
 | 
						|
	  ORDER BY YEAR(n.C_NAPDATUMA), MONTH(n.C_NAPDATUMA)
 | 
						|
 | 
						|
	  INSERT INTO @idoszak (
 | 
						|
		 id
 | 
						|
		,period
 | 
						|
		,startdate
 | 
						|
		,enddate
 | 
						|
	  ) SELECT 
 | 
						|
		6 + ROW_NUMBER() OVER(ORDER BY (SELECT 1))  AS id
 | 
						|
		,IIF(MONTH(n.C_NAPDATUMA) <> 1, CAST(MONTH(n.C_NAPDATUMA) AS varchar(3)), ''1/II'') AS period
 | 
						|
		,IIF(MONTH(n.C_NAPDATUMA) =  1, @masodikFelev, DATEFROMPARTS ( YEAR(n.C_NAPDATUMA), MONTH(n.C_NAPDATUMA), 1 )) AS startdate
 | 
						|
		,DATEADD(m, 1, DATEFROMPARTS ( YEAR(n.C_NAPDATUMA), MONTH(n.C_NAPDATUMA), 1 )) AS enddate
 | 
						|
	  FROM T_NAPTARINAP_OSSZES n
 | 
						|
		INNER JOIN T_TANEV_OSSZES te ON te.ID = n.C_TANEVID
 | 
						|
	  WHERE 
 | 
						|
		  MONTH(n.C_NAPDATUMA) BETWEEN 1 AND 6
 | 
						|
		  AND n.C_TANEVID = @tanevId
 | 
						|
	  GROUP BY YEAR(n.C_NAPDATUMA), MONTH(n.C_NAPDATUMA)
 | 
						|
	  ORDER BY YEAR(n.C_NAPDATUMA), MONTH(n.C_NAPDATUMA)
 | 
						|
 | 
						|
	  INSERT INTO @idoszak (id, period) VALUES
 | 
						|
		(6, ''Félév''), (13, ''Év vége'')  
 | 
						|
 | 
						|
	  DECLARE @jegyek TABLE (
 | 
						|
  		periodId int,
 | 
						|
  		tanuloId int
 | 
						|
		' + ISNULL(',' + @columnList, '') + '
 | 
						|
	  )
 | 
						|
 | 
						|
	  INSERT INTO @jegyek
 | 
						|
	  SELECT id, tanuloID, ' + @pivotList + '
 | 
						|
	  FROM (
 | 
						|
		  SELECT i.id, e.C_TANULOID AS tanuloID, e.C_TANTARGYID as tantargyID,
 | 
						|
		  STUFF((
 | 
						|
				SELECT '', '' + ISNULL(CAST (C_SZAZALEK AS varchar(5)) + ''%'', CAST(sd.C_VALUE  AS varchar(5)))
 | 
						|
				FROM @idoszak si 
 | 
						|
				  LEFT JOIN T_TANULOERTEKELES_OSSZES se ON se.C_ERTEKELESDATUM >= si.startdate AND se.C_ERTEKELESDATUM < si.enddate and se.torolt=''F'' and se.c_tanevId=@tanevId
 | 
						|
    					AND se.C_TANTARGYID = e.C_TANTARGYID
 | 
						|
    					AND se.C_ERTEKELESTIPUSA = e.C_ERTEKELESTIPUSA
 | 
						|
    					AND se.C_TANULOID = e.C_TANULOID 
 | 
						|
				  LEFT JOIN T_DICTIONARYITEMBASE_OSSZES sd ON sd.ID = se.C_OSZTALYZAT AND sd.C_TANEVID=se.C_TANEVID AND sd.C_INTEZMENYID=se.C_INTEZMENYID
 | 
						|
				  LEFT JOIN T_OSZTALYZATERTEKELES_OSSZES oe ON oe.ID=SE.ID AND C_SZAZALEK IS NOT NULL
 | 
						|
				WHERE i.ID = si.ID
 | 
						|
				FOR XML PATH(''''), TYPE).value(''.'', ''varchar(max)''), 1, 2, '''') AS Osztalyzat
 | 
						|
		  FROM T_TANULOERTEKELES_OSSZES e
 | 
						|
			INNER JOIN #students s ON s.id = e.C_TANULOID
 | 
						|
			INNER JOIN @idoszak i ON e.C_ERTEKELESDATUM >= i.startdate AND e.C_ERTEKELESDATUM < i.enddate
 | 
						|
		  WHERE e.C_ERTEKELESTIPUSA = 1518 /* Évközi jegy/értékelés */ and e.c_tanevId=@tanevId
 | 
						|
			AND e.TOROLT = ''F''
 | 
						|
		  GROUP BY e.C_TANULOID, e.C_TANTARGYID, e.C_ERTEKELESTIPUSA, i.id 
 | 
						|
 | 
						|
		  UNION ALL
 | 
						|
 | 
						|
			SELECT 
 | 
						|
				IIF(e.C_ERTEKELESTIPUSA = 1519, 6, 13)
 | 
						|
				,e.C_TANULOID
 | 
						|
				,e.C_TANTARGYID
 | 
						|
				,CAST(MIN(d.C_VALUE) AS varchar(1))
 | 
						|
			FROM #students s
 | 
						|
				INNER JOIN T_TANULOERTEKELES_OSSZES e ON e.C_TANULOID = s.id AND e.C_ERTEKELESTIPUSA IN (1519, 1520)
 | 
						|
				INNER JOIN (select distinct id, c_tanevid, c_value from T_DICTIONARYITEMBASE_OSSZES) d ON d.id = e.C_OSZTALYZAT AND d.C_TANEVID = e.C_TANEVID
 | 
						|
			WHERE e.TOROLT=''F''
 | 
						|
			GROUP BY e.C_TANULOID, e.C_TANTARGYID, e.C_ERTEKELESTIPUSA	 
 | 
						|
		) asd 
 | 
						|
		PIVOT (
 | 
						|
  		MAX(Osztalyzat)
 | 
						|
  		FOR tantargyID IN (' + @pivotList + ')
 | 
						|
		) AS pvt
 | 
						|
 | 
						|
		 SELECT p.id AS periodusId, p.period AS periodusNev, s.id tanuloID, msz.mag Magatartás,  msz.szorg Szorgalom, ' + @selectList + '
 | 
						|
		FROM @idoszak p
 | 
						|
		CROSS JOIN #students s
 | 
						|
	  LEFT JOIN (
 | 
						|
  		SELECT i.id as periodusId, s.id tanuloID, m.C_NAME mag, sz.C_NAME szorg
 | 
						|
  		FROM T_TANULOERTEKELES_OSSZES e
 | 
						|
  			INNER JOIN T_OSZTALYFONOKIERTEKELES_OSSZES oe on oe.ID = e.id and oe.torolt=''F'' --and oe.c_alintezmenyId=@intezmenyId and oe.c_altanevId=@tanevId
 | 
						|
  			INNER JOIN T_DICTIONARYITEMBASE_OSSZES m ON m.ID = oe.C_MAGATARTAS  AND m.C_TANEVID = oe.C_ALTANEVID
 | 
						|
  			INNER JOIN T_DICTIONARYITEMBASE_OSSZES sz ON sz.id = oe.C_SZORGALOM AND sz.C_TANEVID = oe.C_ALTANEVID
 | 
						|
  			INNER JOIN @idoszak i ON e.C_ERTEKELESDATUM >= i.startdate AND e.C_ERTEKELESDATUM < i.enddate
 | 
						|
  			INNER JOIN #students s ON s.id = e.C_TANULOID
 | 
						|
  		WHERE e.C_ERTEKELESTIPUSA = 1518 and e.torolt=''F'' and e.c_intezmenyId=@intezmenyId and e.c_tanevId=@tanevId
 | 
						|
  		GROUP BY i.id, s.id, m.C_NAME, sz.C_NAME
 | 
						|
 | 
						|
  		UNION ALL
 | 
						|
 | 
						|
  		SELECT IIF(e.C_ERTEKELESTIPUSA = 1519, 6, 13), e.C_TANULOID,  ISNULL(m.C_NAME, ISNULL(e.C_ERTEKELESSZOVEG, mJEGY.C_NAME)) mag, ISNULL(sz.C_NAME, ISNULL(e.C_ERTEKELESSZOVEG, szJEGY.C_NAME)) szorg
 | 
						|
  		FROM T_TANULOERTEKELES_OSSZES e 
 | 
						|
  			INNER JOIN #students s ON e.C_TANULOID = s.id AND e.C_ERTEKELESTIPUSA IN (1519, 1520)
 | 
						|
  			INNER JOIN T_OSZTALYFONOKIERTEKELES_OSSZES oe on oe.ID = e.id and oe.torolt=''F'' and oe.c_alintezmenyId=@intezmenyId and oe.c_altanevId=@tanevId
 | 
						|
  			LEFT JOIN T_DICTIONARYITEMBASE_OSSZES m ON m.ID = oe.C_MAGATARTAS  AND m.C_TANEVID = oe.C_ALTANEVID
 | 
						|
  			LEFT JOIN T_DICTIONARYITEMBASE_OSSZES sz ON sz.id = oe.C_SZORGALOM AND sz.C_TANEVID = oe.C_ALTANEVID
 | 
						|
			LEFT JOIN T_DICTIONARYITEMBASE_OSSZES mJEGY ON mJEGY.ID=e.C_OSZTALYZAT AND mJEGY.C_TANEVID = @tanevId
 | 
						|
			LEFT JOIN T_DICTIONARYITEMBASE_OSSZES szJEGY ON szJEGY.ID=e.C_OSZTALYZAT AND szJEGY.C_TANEVID = @tanevId
 | 
						|
  		WHERE e.C_ERTEKELESTIPUSA IN (1519, 1520) AND e.TOROLT=''F''
 | 
						|
  		GROUP BY e.C_ERTEKELESTIPUSA, e.C_TANULOID, m.C_NAME, e.C_ERTEKELESSZOVEG, mJEGY.C_NAME, sz.C_NAME, szJEGY.C_NAME
 | 
						|
	  ) msz ON msz.periodusId = p.id AND msz.tanuloID = s.id
 | 
						|
		LEFT JOIN @jegyek tbl ON tbl.periodId = p.ID AND tbl.tanuloID = s.id
 | 
						|
	  ORDER BY s.id, p.id'
 | 
						|
  
 | 
						|
		IF (@pivotList IS NULL)
 | 
						|
			BEGIN
 | 
						|
				SELECT 0 AS tanuloId
 | 
						|
			END
 | 
						|
		ELSE
 | 
						|
			BEGIN
 | 
						|
				EXEC sp_executesql @sql, N'@osztaly int, @intezmenyId int, @tanevId int', @osztalyId, @intezmenyId, @tanevId
 | 
						|
			END
 | 
						|
	END
 | 
						|
	ELSE
 | 
						|
	BEGIN
 | 
						|
	DECLARE @FelevVegeHonap INT,
 | 
						|
			@FelevVegeNap	INT
 | 
						|
 | 
						|
		SELECT 
 | 
						|
			 @FelevVegeHonap = DATEPART(mm, C_DATUM)
 | 
						|
			,@FelevVegeNap = DATEPART(dd, C_DATUM)
 | 
						|
		FROM T_TANEVRENDJE_OSSZES 
 | 
						|
		WHERE 
 | 
						|
			C_NAPTIPUSA = 1400 
 | 
						|
			AND TOROLT = 'F' 
 | 
						|
			AND C_TANEVID = @tanevid
 | 
						|
 | 
						|
		SELECT * INTO #magatartasSzorgalomTMP FROM
 | 
						|
		(SELECT 
 | 
						|
			'Magatartás' Tipus
 | 
						|
			,IIF(DATEPART(mm, Datum) = @FelevVegeHonap, IIF(DATEPART(mm, Datum) = @FelevVegeHonap AND DATEPART(DD, Datum) <= @FelevVegeNap, 13, 14), DATEPART(mm, Datum))  Honap
 | 
						|
			,TanuloId
 | 
						|
			,Magatartas	Ertekeles
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			Magatartas IS NOT NULL
 | 
						|
			AND Tipusa = 1518
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			'Szorgalom'
 | 
						|
			,IIF(DATEPART(mm, Datum) = @FelevVegeHonap, IIF(DATEPART(mm, Datum) = @FelevVegeHonap AND DATEPART(DD, Datum) <= @FelevVegeNap, 13, 14), DATEPART(mm, Datum))  Honap
 | 
						|
			,TanuloId
 | 
						|
			,Szorgalom 
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			Szorgalom IS NOT NULL
 | 
						|
			AND Tipusa = 1518
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			'Szorgalom'
 | 
						|
			,15  Honap
 | 
						|
			,TanuloId
 | 
						|
			,Szorgalom 
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			Szorgalom IS NOT NULL
 | 
						|
			AND Tipusa = 1519
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			'Magatartás'
 | 
						|
			,15  Honap
 | 
						|
			,TanuloId
 | 
						|
			,Magatartas 
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			Magatartas IS NOT NULL
 | 
						|
			AND Tipusa = 1519
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			'Szorgalom'
 | 
						|
			,16  Honap
 | 
						|
			,TanuloId
 | 
						|
			,Szorgalom 
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			Szorgalom IS NOT NULL
 | 
						|
			AND Tipusa = 1520
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			'Magatartás'
 | 
						|
			,16  Honap
 | 
						|
			,TanuloId
 | 
						|
			,Magatartas 
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			Magatartas IS NOT NULL
 | 
						|
			AND Tipusa = 1520
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			'Magatartás' Tipus
 | 
						|
			,IIF(DATEPART(mm, Datum) = @FelevVegeHonap, IIF(DATEPART(mm, Datum) = @FelevVegeHonap AND DATEPART(DD, Datum) <= @FelevVegeNap, 13, 14), DATEPART(mm, Datum))  Honap
 | 
						|
			,TanuloId
 | 
						|
			,CONVERT(NVARCHAR(MAX),Osztalyzat)
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			Magatartas IS NULL
 | 
						|
			AND TantargyId IS NULL
 | 
						|
			AND Tipusa = 1518
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			'Szorgalom' Tipus
 | 
						|
			,IIF(DATEPART(mm, Datum) = @FelevVegeHonap, IIF(DATEPART(mm, Datum) = @FelevVegeHonap AND DATEPART(DD, Datum) <= @FelevVegeNap, 13, 14), DATEPART(mm, Datum))  Honap
 | 
						|
			,TanuloId
 | 
						|
			,CONVERT(NVARCHAR(MAX),Osztalyzat)
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			Szorgalom IS NULL
 | 
						|
			AND TantargyId IS NULL
 | 
						|
			AND Tipusa = 1518
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			'Magatartás' Tipus
 | 
						|
			,15  Honap
 | 
						|
			,TanuloId
 | 
						|
			,CONVERT(NVARCHAR(MAX),Osztalyzat)
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			Magatartas IS NULL
 | 
						|
			AND TantargyId IS NULL
 | 
						|
			AND Tipusa = 1519
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			'Szorgalom' Tipus
 | 
						|
			,15  Honap
 | 
						|
			,TanuloId
 | 
						|
			,CONVERT(NVARCHAR(MAX),Osztalyzat)
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			Szorgalom IS NULL
 | 
						|
			AND TantargyId IS NULL
 | 
						|
			AND Tipusa = 1519
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			'Magatartás' Tipus
 | 
						|
			,16  Honap
 | 
						|
			,TanuloId
 | 
						|
			,CONVERT(NVARCHAR(MAX),Osztalyzat)
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			Magatartas IS NULL
 | 
						|
			AND TantargyId IS NULL
 | 
						|
			AND Tipusa = 1520
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			'Szorgalom' Tipus
 | 
						|
			,16  Honap
 | 
						|
			,TanuloId
 | 
						|
			,CONVERT(NVARCHAR(MAX),Osztalyzat)
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			Szorgalom IS NULL
 | 
						|
			AND TantargyId IS NULL
 | 
						|
			AND Tipusa = 1520
 | 
						|
		)magszorg
 | 
						|
 | 
						|
		SELECT DISTINCT
 | 
						|
			Honap
 | 
						|
			,TanuloId
 | 
						|
			,Tipus
 | 
						|
			,STUFF((
 | 
						|
				SELECT ', ' + CAST(Ertekeles AS nvarchar(max))
 | 
						|
				FROM #magatartasSzorgalomTMP bmsz 
 | 
						|
				WHERE 
 | 
						|
					msz.TanuloId = bmsz.TanuloId
 | 
						|
					AND msz.Tipus = bmsz.Tipus
 | 
						|
					AND msz.Honap = bmsz.Honap
 | 
						|
				FOR XML PATH(''), TYPE).value('.', 'nvarchar(max)'), 1, 2,'') Ertekeles 	
 | 
						|
			,IIF(Tipus = 'Magatartás', 0, 1) Rendez
 | 
						|
		INTO #magatartasSzorgalom 
 | 
						|
		FROM #magatartasSzorgalomTMP msz
 | 
						|
 | 
						|
		SELECT * INTO #jegyekTMP FROM
 | 
						|
		(SELECT 
 | 
						|
			IIF(DATEPART(mm, Datum) = @FelevVegeHonap, IIF(DATEPART(mm, Datum) = @FelevVegeHonap AND DATEPART(DD, Datum) <= @FelevVegeNap, 13, 14), DATEPART(mm, Datum))  Honap
 | 
						|
			,TanuloId
 | 
						|
			,TantargyId
 | 
						|
			,ISNULL(CONVERT(NVARCHAR(MAX),Osztalyzat), Szazalek) Ertekeles
 | 
						|
			,TargyKategoriaId Rendez
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			TantargyId IS NOT NULL
 | 
						|
			AND SzovegesErtekeles IS NULL
 | 
						|
			AND Tipusa = 1518
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			15  Honap
 | 
						|
			,TanuloId
 | 
						|
			,TantargyId
 | 
						|
			,ISNULL(CONVERT(NVARCHAR(MAX),Osztalyzat), Szazalek) Ertekeles
 | 
						|
			,TargyKategoriaId
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			TantargyId IS NOT NULL
 | 
						|
			AND SzovegesErtekeles IS NULL
 | 
						|
			AND Tipusa = 1519
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			16  Honap
 | 
						|
			,TanuloId
 | 
						|
			,TantargyId
 | 
						|
			,ISNULL(CONVERT(NVARCHAR(MAX),Osztalyzat), Szazalek) Ertekeles
 | 
						|
			,TargyKategoriaId
 | 
						|
		FROM fnGetDokumentumErtekelesekOsztalyonkent(@tanevid, @osztalyid)
 | 
						|
		WHERE
 | 
						|
			TantargyId IS NOT NULL
 | 
						|
			AND SzovegesErtekeles IS NULL
 | 
						|
			AND Tipusa = 1520
 | 
						|
		)jegyek
 | 
						|
 | 
						|
		SELECT DISTINCT
 | 
						|
			Honap
 | 
						|
			,TanuloId
 | 
						|
			,TantargyId
 | 
						|
			,STUFF((
 | 
						|
				SELECT ', ' + CAST(Ertekeles AS nvarchar(max))
 | 
						|
				FROM #jegyekTMP bj 
 | 
						|
				WHERE 
 | 
						|
					j.TanuloId = bj.TanuloId
 | 
						|
					AND j.TantargyId = bj.TantargyId
 | 
						|
					AND j.Honap = bj.Honap
 | 
						|
				FOR XML PATH(''), TYPE).value('.', 'nvarchar(max)'), 1, 2,'') Ertekeles 	
 | 
						|
			,Rendez
 | 
						|
		INTO #jegyek 
 | 
						|
		FROM #jegyekTMP j
 | 
						|
 | 
						|
		SELECT * FROM 
 | 
						|
		(SELECT * 
 | 
						|
		FROM #magatartasSzorgalom
 | 
						|
		PIVOT (MAX(Ertekeles) FOR Honap IN ([9],[10],[11],[12],[2],[3],[4],[5],[6],[13],[14],[15],[16])) piv
 | 
						|
		UNION ALL
 | 
						|
		SELECT 
 | 
						|
			TanuloId		TanuloId
 | 
						|
			,C_NEV			TantargyNev
 | 
						|
			,Rendez
 | 
						|
			,[9],[10],[11],[12],[2],[3],[4],[5],[6],[13],[14],[15],[16]	
 | 
						|
		FROM #jegyek 
 | 
						|
			INNER JOIN (SELECT Id, C_NEV FROM T_TANTARGY_OSSZES) t ON t.Id = TantargyId
 | 
						|
		PIVOT (MAX(Ertekeles) FOR Honap IN ([9],[10],[11],[12],[2],[3],[4],[5],[6],[13],[14],[15],[16])) piv
 | 
						|
		)vegleges
 | 
						|
		ORDER BY TanuloId, Rendez, Tipus
 | 
						|
 | 
						|
		DROP TABLE #jegyekTMP
 | 
						|
		DROP TABLE #jegyek
 | 
						|
		DROP TABLE #magatartasSzorgalomTMP
 | 
						|
		DROP TABLE #magatartasSzorgalom
 | 
						|
	END
 | 
						|
 | 
						|
 | 
						|
  /* TANULÓ záradékai */
 | 
						|
	SELECT
 | 
						|
		students.ID tanuloId
 | 
						|
		,tanuloCsoport.C_ZARADEK zaradek
 | 
						|
	FROM #students students
 | 
						|
		INNER JOIN T_TANULOCSOPORT_OSSZES tanuloCsoport on students.ID = tanuloCsoport.C_TANULOID
 | 
						|
	WHERE 
 | 
						|
		tanuloCsoport.C_OSZTALYCSOPORTID = @osztalyId
 | 
						|
		AND TOROLT = 'F'
 | 
						|
  
 | 
						|
  /*Szöveges minősítések*/
 | 
						|
	SELECT 
 | 
						|
		s.id tanuloId
 | 
						|
		, szoveges.Honap
 | 
						|
		, szoveges.Tantargy
 | 
						|
		, szoveges.Ertekeles 
 | 
						|
	FROM #students s
 | 
						|
	LEFT JOIN (SELECT 
 | 
						|
					C_TANULOID tanuloId
 | 
						|
					, '['+CONVERT(NVARCHAR(MAX),DATEPART(MONTH, C_ERTEKELESDATUM))+'. hónap]' Honap
 | 
						|
					, IIF(t.C_NEV <> C_NEVNYOMTATVANYBAN AND C_NEVNYOMTATVANYBAN IS NOT NULL, C_NEVNYOMTATVANYBAN + ' (' + t.C_NEV + ')', t.C_NEV) Tantargy
 | 
						|
					, C_ERTEKELESSZOVEG Ertekeles 
 | 
						|
				FROM T_TANULOERTEKELES_OSSZES te 
 | 
						|
					INNER JOIN T_TANTARGY_OSSZES t on t.ID=te.C_TANTARGYID
 | 
						|
				WHERE 
 | 
						|
					C_TANULOID IN (SELECT ID FROM #students) 
 | 
						|
					AND C_ERTEKELESSZOVEG IS NOT NULL 
 | 
						|
					AND te.C_TANEVID=@tanevId 
 | 
						|
					AND te.TOROLT='F'
 | 
						|
			) szoveges on szoveges.TANULOID=s.Id
 | 
						|
	ORDER BY Honap, Tantargy
 | 
						|
 | 
						|
DROP TABLE #students	
 | 
						|
DROP TABLE #osztalycsoportok
 | 
						|
DROP TABLE #OsztalyVagyTanoraiCsoport
 | 
						|
DROP TABLE #megtartottOrak
 | 
						|
DROP TABLE #OraSorszam
 | 
						|
 | 
						|
END
 | 
						|
 | 
						|
GO |