init
This commit is contained in:
@@ -0,0 +1,41 @@
|
||||
IF OBJECT_ID('fnGetDokumentumMulasztasokOsztalyonkentReszletes') IS NOT NULL BEGIN
|
||||
DROP FUNCTION fnGetDokumentumMulasztasokOsztalyonkentReszletes
|
||||
END
|
||||
GO
|
||||
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
CREATE FUNCTION fnGetDokumentumMulasztasokOsztalyonkentReszletes (@tanevId INT, @osztalyCsoportId INT, @iskolaErdekuSzamit BIT)
|
||||
RETURNS TABLE
|
||||
RETURN (
|
||||
SELECT
|
||||
C_ORATANULOIID TanuloId
|
||||
,C_OSZTALYCSOPORTID OsztalyCsoportId
|
||||
,ocs.C_NEV OsztalyCsoportNev
|
||||
,C_TIPUS Tipusa
|
||||
,C_IGAZOLT Igazolt
|
||||
,C_IGAZOLASTIPUSA IgazolasTipusa
|
||||
,C_KESESPERCBEN KesesPercben
|
||||
,C_DATUM Datum
|
||||
,C_ORASZAM Oraszam
|
||||
,C_TANTARGYID TantargyId
|
||||
,t.C_NEVNYOMTATVANYBAN TantargyNev
|
||||
FROM T_TANULOMULASZTAS_OSSZES tm
|
||||
INNER JOIN T_TANITASIORA_OSSZES tao ON tao.ID = tm.C_TANITASIORAKID
|
||||
INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs ON ocs.ID = tao.C_OSZTALYCSOPORTID
|
||||
INNER JOIN T_TANTARGY_OSSZES t on t.ID = tao.C_TANTARGYID
|
||||
WHERE
|
||||
C_ORATANULOIID IN (SELECT TanuloId FROM fnGetDokumentumOsztalyokCsoportokTanuloi(@tanevId, @osztalyCsoportId, 'T'))
|
||||
AND C_TIPUS IN (1499, 1500)
|
||||
AND tao.C_OSZTALYCSOPORTID IN (SELECT Id FROM fnGetDokumentumOsztalyVagyTanoraiCsoport(@tanevId))
|
||||
AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
|
||||
AND tm.TOROLT = 'F'
|
||||
)
|
||||
|
||||
|
||||
|
||||
|
||||
|
@@ -0,0 +1,23 @@
|
||||
IF OBJECT_ID('fnGetDokumentumOsztalyokCsoportokTanuloi') IS NOT NULL BEGIN
|
||||
DROP FUNCTION fnGetDokumentumOsztalyokCsoportokTanuloi
|
||||
END
|
||||
GO
|
||||
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
CREATE FUNCTION fnGetDokumentumOsztalyokCsoportokTanuloi (@tanevId INT, @osztalyId INT, @isKilepettTanulokMegjelenjenek NVARCHAR(1))
|
||||
RETURNS TABLE
|
||||
RETURN (
|
||||
SELECT DISTINCT
|
||||
C_TANULOID TanuloId
|
||||
FROM
|
||||
T_TANULOCSOPORT_OSSZES
|
||||
WHERE
|
||||
C_OSZTALYCSOPORTID = @osztalyId
|
||||
AND C_TANEVID = @tanevId
|
||||
AND TOROLT = 'F'
|
||||
AND (@isKilepettTanulokMegjelenjenek = 'T' OR C_KILEPESDATUM IS NULL)
|
||||
)
|
@@ -0,0 +1,39 @@
|
||||
IF OBJECT_ID('fnGetDokumentumTanulokEvesOraszamaiOsztalynkonet') IS NOT NULL BEGIN
|
||||
DROP FUNCTION fnGetDokumentumTanulokEvesOraszamaiOsztalynkonet
|
||||
END
|
||||
GO
|
||||
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
CREATE FUNCTION fnGetDokumentumTanulokEvesOraszamaiOsztalynkonet (@tanevId int, @osztalyId int)
|
||||
RETURNS TABLE
|
||||
RETURN (
|
||||
SELECT
|
||||
C_TANULOID TanuloId
|
||||
, ISNULL(t.C_FOTARGYID, t.ID) TantargyId
|
||||
, SUM(fog.C_ORASZAM) * IIF((SELECT C_VEGZOSEVFOLYAM FROM T_OSZTALYCSOPORT_OSSZES WHERE ID = @osztalyId) = 'T', 32, 36) Oraszam
|
||||
FROM
|
||||
T_TANULOCSOPORT_OSSZES tcs
|
||||
INNER JOIN T_FOGLALKOZAS_OSSZES fog ON fog.C_OSZTALYCSOPORTID = tcs.C_OSZTALYCSOPORTID
|
||||
INNER JOIN T_TANTARGY_OSSZES t on t.ID = fog.C_TANTARGYID AND (t.C_FOTARGYE = 'T' OR t.C_ALTANTARGYKENTNYOMTATVANYBAN='T')
|
||||
WHERE
|
||||
tcs.C_TANULOID IN ( SELECT TanuloId FROM fnGetDokumentumOsztalyokCsoportokTanuloi(@tanevId, @osztalyId, 'T') )
|
||||
AND ((tcs.C_OSZTALYCSOPORTID IN (SELECT ID FROM T_OSZTALY_OSSZES)) OR (tcs.C_OSZTALYCSOPORTID IN (SELECT ID FROM T_CSOPORT_OSSZES WHERE C_TIPUSA=1034)))
|
||||
AND tcs.TOROLT = 'F'
|
||||
AND tcs.C_TANEVID = @tanevId
|
||||
AND ISNULL(tcs.C_KILEPESDATUM, IIF(
|
||||
(SELECT C_VEGZOSEVFOLYAM FROM T_OSZTALYCSOPORT_OSSZES WHERE ID = @osztalyId) = 'T',
|
||||
(SELECT C_DATUM FROM T_TANEVRENDJE_OSSZES WHERE C_TANEVID = @tanevId AND TOROLT = 'F' AND C_NAPTIPUSA = 1402), --végzős
|
||||
(SELECT C_DATUM FROM T_TANEVRENDJE_OSSZES WHERE C_TANEVID = @tanevId AND TOROLT = 'F' AND C_NAPTIPUSA = 1395) --nem végzős
|
||||
)
|
||||
)
|
||||
>= IIF(
|
||||
(SELECT C_VEGZOSEVFOLYAM FROM T_OSZTALYCSOPORT_OSSZES WHERE ID = @osztalyId) = 'T',
|
||||
(SELECT C_DATUM FROM T_TANEVRENDJE_OSSZES WHERE C_TANEVID = @tanevId AND TOROLT = 'F' AND C_NAPTIPUSA = 1402), --végzős
|
||||
(SELECT C_DATUM FROM T_TANEVRENDJE_OSSZES WHERE C_TANEVID = @tanevId AND TOROLT = 'F' AND C_NAPTIPUSA = 1395) --nem végzős
|
||||
)
|
||||
GROUP BY C_TANULOID, t.C_FOTARGYID, t.ID
|
||||
)
|
@@ -0,0 +1,51 @@
|
||||
IF OBJECT_ID('fnGetDokumentumTanulokFeljegyzesei') IS NOT NULL BEGIN
|
||||
DROP FUNCTION fnGetDokumentumTanulokFeljegyzesei
|
||||
END
|
||||
GO
|
||||
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
CREATE FUNCTION fnGetDokumentumTanulokFeljegyzesei (@tanevId INT, @osztalyId INT)
|
||||
RETURNS TABLE
|
||||
RETURN (
|
||||
SELECT
|
||||
tanulok.TanuloId TanuloId
|
||||
,te.ID EsemenyId
|
||||
,te.C_TARTALOM Tartalom
|
||||
,te.C_TIPUS Tipusa
|
||||
,feljegyezo.C_NYOMTATASINEV FeljegyzoNeve
|
||||
,te.C_KEZDETE Datum
|
||||
,te.C_MEGJEGYZES Megjegyzes
|
||||
FROM T_TANULOESEMENY_OSSZES te
|
||||
INNER JOIN T_TANITASIORA_OSSZES tao on tao.Id = te.C_TANITASIORAID
|
||||
CROSS APPLY (SELECT TanuloId FROM fnGetDokumentumOsztalyokCsoportokTanuloi(@tanevId, tao.C_OSZTALYCSOPORTID, 'T')) tanulok
|
||||
INNER JOIN fnGetDokumentumTanulokOsztalybanToltottNapjai(@tanevId, @osztalyId) tanuloDatum
|
||||
ON
|
||||
tanuloDatum.TanuloId = tanulok.TanuloId
|
||||
AND tanuloDatum.NapDatuma = tao.C_DATUM
|
||||
INNER JOIN T_FELHASZNALO_OSSZES feljegyezo ON feljegyezo.ID = te.C_FELJEGYZOID
|
||||
WHERE
|
||||
C_MINDENKINEK = 'T'
|
||||
AND te.TOROLT = 'F'
|
||||
AND tao.C_OSZTALYCSOPORTID IN (SELECT ID FROM fnGetKapcsolodoOsztalycsoportok(@osztalyId))
|
||||
|
||||
UNION
|
||||
|
||||
SELECT
|
||||
C_TANULOID TanuloId
|
||||
,te.ID EsemenyId
|
||||
,te.C_TARTALOM Tartalom
|
||||
,te.C_TIPUS Tipusa
|
||||
,feljegyezo.C_NYOMTATASINEV FeljegyzoNeve
|
||||
,te.C_KEZDETE Datum
|
||||
,te.C_MEGJEGYZES Megjegyzes
|
||||
FROM T_TANULO_TANULOESEMENY_OSSZES tte
|
||||
INNER JOIN T_TANULOESEMENY_OSSZES te on te.ID = tte.C_TANULOESEMENYID
|
||||
INNER JOIN T_FELHASZNALO_OSSZES feljegyezo ON feljegyezo.ID = te.C_FELJEGYZOID
|
||||
WHERE
|
||||
C_TANULOID IN (SELECT TanuloId FROM fnGetDokumentumOsztalyokCsoportokTanuloi(@tanevId, @osztalyId, 'T'))
|
||||
AND te.TOROLT = 'F'
|
||||
)
|
@@ -0,0 +1,27 @@
|
||||
IF OBJECT_ID('fnGetDokumentumTanulokOsztalybanToltottNapjai') IS NOT NULL BEGIN
|
||||
DROP FUNCTION fnGetDokumentumTanulokOsztalybanToltottNapjai
|
||||
END
|
||||
GO
|
||||
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
CREATE FUNCTION fnGetDokumentumTanulokOsztalybanToltottNapjai (@tanevId INT, @osztalyId INT)
|
||||
RETURNS TABLE
|
||||
RETURN (
|
||||
SELECT
|
||||
C_TANULOID TanuloId
|
||||
, naptar.C_NAPDATUMA NapDatuma
|
||||
FROM T_TANULOCSOPORT_OSSZES tcs
|
||||
INNER JOIN T_NAPTARINAP_OSSZES naptar
|
||||
ON
|
||||
tcs.C_BELEPESDATUM <= naptar.C_NAPDATUMA
|
||||
AND ISNULL(tcs.C_KILEPESDATUM, (SELECT C_DATUM FROM T_TANEVRENDJE_OSSZES WHERE C_NAPTIPUSA = 1395 AND C_TANEVID = @tanevId AND TOROLT = 'F')) >= naptar.C_NAPDATUMA
|
||||
AND naptar.C_TANEVID = @tanevId
|
||||
AND naptar.TOROLT = 'F'
|
||||
WHERE
|
||||
C_OSZTALYCSOPORTID = @osztalyId
|
||||
AND tcs.TOROLT = 'F'
|
||||
)
|
@@ -0,0 +1,258 @@
|
||||
IF OBJECT_ID('[dbo].[sp_GetCsoportNaplo]') IS NOT NULL BEGIN
|
||||
DROP PROCEDURE [dbo].[sp_GetCsoportNaplo]
|
||||
END
|
||||
GO
|
||||
|
||||
CREATE PROCEDURE [dbo].[sp_GetCsoportNaplo]
|
||||
@tanevId INT,
|
||||
@intezmenyid INT,
|
||||
@csoportId INT,
|
||||
@iskolaErdekuSzamit BIT
|
||||
|
||||
AS
|
||||
BEGIN
|
||||
SET NOCOUNT ON;
|
||||
|
||||
--Tanulók adatai, elérhetőségei
|
||||
DECLARE @tanulok TABLE (
|
||||
Id int
|
||||
,Nev nvarchar(max)
|
||||
,Osztaly nvarchar(max)
|
||||
,Sorszam nvarchar(max)
|
||||
,Torzslapszam nvarchar(max)
|
||||
,Allampolgarsaga nvarchar(max)
|
||||
,DiakIg nvarchar(max)
|
||||
,SzulHely nvarchar(max)
|
||||
,SzulIdo nvarchar(max)
|
||||
,Anyja nvarchar(max)
|
||||
,Taj nvarchar(20)
|
||||
,OktAzon nvarchar(20)
|
||||
,Kilepes nvarchar(max)
|
||||
,Kepzes nvarchar(max)
|
||||
,TanuloCimTipus nvarchar(max)
|
||||
,TanuloCim nvarchar(max)
|
||||
,TanuloTelefon nvarchar(max)
|
||||
,TanuloEmail nvarchar(max)
|
||||
,szoc nvarchar(max)
|
||||
)
|
||||
|
||||
INSERT INTO @tanulok
|
||||
SELECT DISTINCT
|
||||
t.id Id
|
||||
,iif(tcs.C_KILEPESDATUM is not null, f.C_NYOMTATASINEV + ' (kilépett)',f.c_nyomtatasinev) as Nev
|
||||
,Osztaly.Osztaly as Osztaly
|
||||
,t.c_naplosorszam as Sorszam
|
||||
,t.c_beirasinaplosorszam as Torzslapszam
|
||||
,Allampolgarsaga.C_NAME as Allampolgarsag
|
||||
,t.c_diakigazolvanyszam as DiakIg
|
||||
,f.c_szuletesihely as SzulHely
|
||||
,FORMAT(f.c_szuletesidatum, 'yyyy. MMMM dd.', 'hu-hu') as SzulIdo
|
||||
,f.c_anyjaneve as Anyja
|
||||
,f.c_tajszam as Taj
|
||||
,f.c_oktatasiazonosito as OktAzon
|
||||
,FORMAT(tcs.c_kilepesdatum, 'yyyy. MMMM dd.', 'hu-hu') as Kilepes
|
||||
,tt.c_nev as Kepzes
|
||||
,cim.Tipus
|
||||
,cim.cim
|
||||
,tel.c_telefonszam
|
||||
,email.c_emailcim as TanuloEmail
|
||||
,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 szoc
|
||||
FROM T_TANULOCSOPORT_OSSZES tcs
|
||||
INNER JOIN T_FELHASZNALO_OSSZES f ON f.id=tcs.c_tanuloid AND f.torolt='F'
|
||||
INNER JOIN T_DICTIONARYITEMBASE_OSSZES Allampolgarsaga ON Allampolgarsaga.Id = f.c_allampolgarsaga AND Allampolgarsaga.C_TANEVID = f.C_TANEVID
|
||||
LEFT JOIN (
|
||||
SELECT tcs.c_tanuloid TanuloId, ocs.c_nev as Osztaly, tcs.c_kilepesdatum Kilepes
|
||||
FROM T_TANULOCSOPORT_OSSZES tcs
|
||||
INNER JOIN T_OSZTALY_OSSZES o ON o.id=tcs.c_osztalycsoportid
|
||||
INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs ON o.id=ocs.id
|
||||
) osztaly ON tcs.c_tanuloid=osztaly.TanuloId
|
||||
INNER JOIN T_TANTERV_OSSZES tt ON tt.c_intezmenyid=tcs.c_intezmenyid AND tt.c_intezmenyid=@intezmenyid AND tt.c_tanevid=@tanevid
|
||||
INNER JOIN T_TANULO_OSSZES t ON t.id=f.id
|
||||
INNER JOIN (
|
||||
SELECT f.id Tanulo, dt.c_name Tipus, c.c_iranyitoszam+', '+c.c_varos+' '+c.c_kozterulet+' '+dj.c_name+' '+c.c_hazszam as Cim
|
||||
FROM t_cim_osszes c
|
||||
INNER JOIN (select distinct d.id, d.c_name from T_DICTIONARYITEMBASE_OSSZES d )dt ON dt.id=c.c_cimtipusa
|
||||
INNER JOIN T_FELHASZNALO_OSSZES f ON f.id=c.c_felhasznaloid
|
||||
INNER JOIN (select distinct d.id, d.c_name from T_DICTIONARYITEMBASE_OSSZES d)dj ON dj.id=c.c_kozteruletjellege
|
||||
WHERE c.c_cimtipusa = 907
|
||||
AND c.c_gondviseloid is null
|
||||
AND c.torolt='F'
|
||||
AND c.c_tanevid=@tanevId
|
||||
) cim ON cim.Tanulo=tcs.c_tanuloid
|
||||
LEFT JOIN T_TELEFON_OSSZES tel ON tel.c_felhasznaloid = f.id AND tel.c_gondviseloid IS NULL AND tel.torolt = 'F' AND tel.c_alapertelmezett = 'T'
|
||||
LEFT JOIN T_EMAIL_OSSZES email ON email.c_felhasznaloid = tcs.c_tanuloid AND email.c_gondviseloid IS NULL AND email.torolt = 'F' AND email.c_alapertelmezett = 'T'
|
||||
WHERE tcs.c_osztalycsoportid = @csoportId AND tcs.c_tanevid = @tanevid
|
||||
|
||||
--Kezdőoldal
|
||||
SELECT
|
||||
ia.c_nev as IntezmenyNev
|
||||
,ia.c_cime as IntezmenyCim
|
||||
,ia.c_omkod as OMKOD
|
||||
,ia.c_igazgatoneve as IntezmenyVezeto
|
||||
,ocs.c_nev Csoport
|
||||
,isnull(f.c_nyomtatasinev,'-') as CsoportVezeto
|
||||
,isnull(cs.c_csoportnaploleiras,'-') as CsoportNaploLeiras
|
||||
,FORMAT(cs.c_csoportnaplomegnyitasa, 'yyyy. MMMM dd.', 'hu-hu') as Megnyitas
|
||||
,isnull(FORMAT(cs.c_csoportnaplozarasa, 'yyyy. MMMM dd.', 'hu-hu'),'-') as Lezaras
|
||||
,ocs.c_nev RovidNev
|
||||
FROM T_INTEZMENY_OSSZES i
|
||||
INNER JOIN T_INTEZMENYADATOK_OSSZES ia ON ia.c_intezmenyid = i.id
|
||||
INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs ON ocs.c_intezmenyid = i.id AND ocs.c_tanevid = @tanevid
|
||||
INNER JOIN T_CSOPORT_OSSZES cs ON cs.id = ocs.id
|
||||
LEFT JOIN T_FELHASZNALO_OSSZES f ON f.id=cs.c_csoportvezetoid
|
||||
WHERE i.id = @intezmenyid AND ia.c_tanevid = @tanevid AND ocs.id = @csoportId
|
||||
|
||||
--Csoportot vezette
|
||||
SELECT isnull(f.c_nyomtatasinev,'-') as CsoportVezeto
|
||||
FROM T_CSOPORT_OSSZES cs
|
||||
LEFT JOIN T_FELHASZNALO_OSSZES f ON f.id = cs.c_csoportvezetoid
|
||||
WHERE cs.id = @csoportId
|
||||
|
||||
--Tanulók
|
||||
SELECT DISTINCT Nev, Osztaly, OktAzon FROM @tanulok
|
||||
|
||||
--Naplóhetek
|
||||
DECLARE @elsonap as date
|
||||
DECLARE @utolsonap as date
|
||||
|
||||
select @elsonap=c_elsotanitasinap, @utolsonap=c_utolsotanitasinap from t_tanev_osszes where id=@tanevId
|
||||
|
||||
SELECT
|
||||
n.c_hetsorszama as Het
|
||||
,FORMAT(convert(date,min(c_napdatuma)), 'yyyy. MMMM dd.', 'hu-hu')as HetEleje
|
||||
,FORMAT(convert(date,max(c_napdatuma)), 'yyyy. MMMM dd.', 'hu-hu') as HetVege
|
||||
FROM T_NAPTARINAP_OSSZES n
|
||||
WHERE n.c_napdatuma >= @elsonap
|
||||
AND n.c_napdatuma <= @utolsonap
|
||||
AND n.c_orarendinap = 'T'
|
||||
AND n.c_tanevid = @tanevid
|
||||
AND n.c_intezmenyid = @intezmenyid
|
||||
GROUP BY n.c_hetsorszama
|
||||
|
||||
--Tanuló adatok
|
||||
SELECT * FROM @tanulok
|
||||
|
||||
--Napló
|
||||
SELECT DISTINCT
|
||||
nn.c_hetsorszama as Het
|
||||
,d.Nap as Nap
|
||||
,FORMAT(nn.c_napdatuma, 'yyyy. MMMM dd.', 'hu-hu') as Datum
|
||||
FROM T_NAPTARINAP_OSSZES nn
|
||||
LEFT JOIN T_TANITASIORA_OSSZES tao ON tao.c_datum = nn.c_napdatuma AND tao.c_osztalycsoportid = @csoportid AND tao.torolt = 'F'
|
||||
LEFT JOIN (select distinct d.id as ID, d.c_name Nap from T_DICTIONARYITEMBASE_OSSZES d) d ON d.id = nn.c_hetnapja
|
||||
LEFT JOIN T_FOGLALKOZAS_OSSZES fog ON fog.id=tao.c_foglalkozasid AND fog.c_tanevid = @tanevid
|
||||
LEFT JOIN T_FOGLALKOZASOK_TANAROK_OSSZES ft ON ft.c_foglalkozasokid=fog.id
|
||||
LEFT JOIN T_FELHASZNALO_OSSZES f ON f.id=ft.c_tanarokid AND f.torolt='F'
|
||||
WHERE nn.c_orarendinap='T' AND nn.c_napdatuma >= @elsonap AND nn.c_napdatuma <= @utolsonap
|
||||
ORDER BY nn.c_hetsorszama, FORMAT(nn.c_napdatuma, 'yyyy. MMMM dd.', 'hu-hu')
|
||||
|
||||
--Napló adatok
|
||||
DECLARE @Orak TABLE (
|
||||
datum date
|
||||
,Sorszam int
|
||||
,Hetsorszam int
|
||||
)
|
||||
|
||||
INSERT INTO @Orak
|
||||
SELECT DISTINCT
|
||||
n.c_napdatuma datum
|
||||
,sz.Oraszam
|
||||
,n.c_hetsorszama
|
||||
FROM T_NAPTARINAP_OSSZES n
|
||||
CROSS JOIN (VALUES (1),(2),(3),(4),(5),(6),(7),(8),(9),(10)) sz (Oraszam)
|
||||
WHERE n.c_napdatuma >= @elsonap
|
||||
AND n.c_napdatuma <= @utolsonap
|
||||
AND n.c_orarendinap = 'T'
|
||||
AND TOROLT = 'F'
|
||||
AND n.C_TANEVID = @tanevId
|
||||
|
||||
DECLARE @oraSorszam TABLE (Id int, EvesSorszam int)
|
||||
|
||||
INSERT INTO @oraSorszam (Id, EvesSorszam)
|
||||
SELECT DISTINCT
|
||||
s.Id
|
||||
,s.EvesSorszam
|
||||
FROM (
|
||||
SELECT DISTINCT tn.C_TANTARGYID, tn.C_OSZTALYCSOPORTID, ot.C_TANAROKID, tn.C_INTEZMENYID--, fh.C_NYOMTATASINEV
|
||||
FROM T_TANITASIORA_OSSZES tn
|
||||
INNER JOIN T_ORAK_TANAROK ot ON tn.ID = ot.C_ORAKID
|
||||
INNER JOIN T_FELHASZNALO fh ON fh.ID = ot.C_TANAROKID
|
||||
WHERE tn.C_OSZTALYCSOPORTID = @csoportid
|
||||
) x
|
||||
CROSS APPLY dbo.fnGetEvesOraszamLista (
|
||||
x.C_TANTARGYID
|
||||
,x.C_OSZTALYCSOPORTID
|
||||
,x.C_TANAROKID
|
||||
,GETDATE()
|
||||
,x.C_INTEZMENYID
|
||||
,@tanevID
|
||||
) s
|
||||
|
||||
SELECT DISTINCT
|
||||
o.Hetsorszam as Het
|
||||
,o.Sorszam as Oraszam
|
||||
,FORMAT(o.Datum, 'yyyy. MMMM dd.', 'hu-hu') as Datum
|
||||
,FORMAT(tao.c_orakezdete, 'hh:mm')as OraKezd
|
||||
,fh.C_NYOMTATASINEV as Tanar
|
||||
,os.EvesSorszam as Sorszam
|
||||
,tao.c_tema as Tema
|
||||
FROM @Orak o
|
||||
LEFT JOIN T_TANITASIORA_OSSZES tao ON tao.c_datum = o.Datum
|
||||
AND tao.torolt = 'F'
|
||||
AND tao.c_oraszam = o.Sorszam
|
||||
AND tao.c_tanevid = @tanevid
|
||||
AND tao.c_osztalycsoportid = @csoportid
|
||||
LEFT JOIN @oraSorszam os ON os.Id = tao.ID
|
||||
LEFT JOIN T_ORAK_TANAROK ot ON tao.ID = ot.C_ORAKID
|
||||
LEFT JOIN T_FELHASZNALO fh ON fh.ID = ot.C_TANAROKID
|
||||
ORDER BY Oraszam
|
||||
|
||||
|
||||
--Napló mulasztás
|
||||
SELECT C_HETSORSZAMA Het, C_NYOMTATASINEV Tanulo,
|
||||
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 T_OSZTALYCSOPORT_OSSZES ocs ON ocs.id=@csoportid
|
||||
WHERE n.C_NAPTARINAPID = o.C_NAPTARINAPID
|
||||
AND m.C_ORATANULOIID = tm.C_ORATANULOIID
|
||||
AND o.C_TANEVID = @tanevID
|
||||
AND tm.C_TANEVID = @tanevID
|
||||
AND TM.TOROLT='F'
|
||||
AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
|
||||
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 T_FELHASZNALO_OSSZES t ON t.ID = m.C_ORATANULOIID
|
||||
WHERE
|
||||
n.C_TANEVID = @tanevID
|
||||
AND m.C_TANEVID = @tanevID
|
||||
AND n.c_osztalycsoportid=@csoportId
|
||||
AND n.torolt='F'
|
||||
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 x
|
||||
GROUP BY C_HETSORSZAMA, C_NYOMTATASINEV
|
||||
ORDER BY C_HETSORSZAMA
|
||||
END
|
||||
|
||||
GO
|
@@ -0,0 +1,111 @@
|
||||
GO
|
||||
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
IF OBJECT_ID('sp_GetDokumentumErtekelesek') IS NOT NULL BEGIN
|
||||
DROP PROCEDURE [sp_GetDokumentumErtekelesek]
|
||||
END
|
||||
GO
|
||||
|
||||
CREATE PROCEDURE sp_GetDokumentumErtekelesek
|
||||
@osztalyId int,
|
||||
@tanevId int,
|
||||
@ertekelesTipus int,
|
||||
@isBizonyitvany int = 0
|
||||
|
||||
AS
|
||||
BEGIN
|
||||
SET NOCOUNT ON;
|
||||
|
||||
--Osztályhoz tartozó tanulók
|
||||
DECLARE @Tanulok TABLE (TanuloId INT PRIMARY KEY)
|
||||
INSERT INTO @Tanulok
|
||||
SELECT TanuloId FROM fnGetDokumentumOsztalyokCsoportokTanuloi(@tanevId, @osztalyId, 'T')
|
||||
|
||||
--Tanulóhoz kapcsolódó óraszámok
|
||||
DECLARE @Oraszamok TABLE (TanuloId int, Tantargy INT, Oraszam INT)
|
||||
|
||||
INSERT INTO @Oraszamok
|
||||
SELECT * FROM fnGetDokumentumTanulokEvesOraszamaiOsztalynkonet(@tanevId, @osztalyId)
|
||||
|
||||
--Értékelések
|
||||
SELECT
|
||||
ERTEKELES.C_TANULOID TANULOID
|
||||
, 'MAGATARTAS' TARGY
|
||||
, ISNULL(ERT.C_NAME, ISNULL(ERTEKELES.C_ERTEKELESSZOVEG, JEGY.C_NAME)) Ertekeles
|
||||
, NULL Jegyzet
|
||||
, ISNULL(ERT.C_NAME, ISNULL(ERTEKELES.C_ERTEKELESSZOVEG, JEGY.C_NAME)) ErtekelesJegyzettel
|
||||
, ISNULL(ERT.C_NAME, ISNULL(ERTEKELES.C_ERTEKELESSZOVEG, JEGY.C_NAME)) SzovegesErtekeles
|
||||
, NULL Oraszam
|
||||
, 1 RENDEZ
|
||||
FROM T_TANULOERTEKELES_OSSZES ERTEKELES
|
||||
INNER JOIN @Tanulok TANCSOPORT
|
||||
ON TANCSOPORT.TanuloId = ERTEKELES.C_TANULOID
|
||||
LEFT JOIN T_OSZTALYFONOKIERTEKELES_OSSZES OSZTALYZAT
|
||||
ON OSZTALYZAT.ID = ERTEKELES.ID
|
||||
LEFT JOIN T_DICTIONARYITEMBASE_OSSZES ERT ON ERT.ID=OSZTALYZAT.C_MAGATARTAS AND ERT.C_TANEVID = @tanevId
|
||||
LEFT JOIN T_DICTIONARYITEMBASE_OSSZES JEGY ON JEGY.ID=ERTEKELES.C_OSZTALYZAT AND JEGY.C_TANEVID = @tanevId
|
||||
WHERE
|
||||
ERTEKELES.C_ERTEKELESTIPUSA = @ertekelesTipus
|
||||
AND ERTEKELES.C_TANEVID = @tanevId
|
||||
AND ERTEKELES.TOROLT='F'
|
||||
AND OSZTALYZAT.TOROLT = 'F'
|
||||
|
||||
UNION
|
||||
|
||||
SELECT
|
||||
ERTEKELES.C_TANULOID TANULOID
|
||||
, 'SZORGALOM' TARGY
|
||||
, ISNULL(ERT.C_NAME, ISNULL(ERTEKELES.C_ERTEKELESSZOVEG, JEGY.C_NAME)) Ertekeles
|
||||
, NULL Jegyzet
|
||||
, ISNULL(ERT.C_NAME, ISNULL(ERTEKELES.C_ERTEKELESSZOVEG, JEGY.C_NAME)) ErtekelesJegyzettel
|
||||
, ISNULL(ERT.C_NAME, ISNULL(ERTEKELES.C_ERTEKELESSZOVEG, JEGY.C_NAME)) SzovegesErtekeles
|
||||
, NULL Oraszam
|
||||
, 2 RENDEZ
|
||||
FROM T_TANULOERTEKELES_OSSZES ERTEKELES
|
||||
INNER JOIN @Tanulok TANCSOPORT
|
||||
ON TANCSOPORT.TanuloId = ERTEKELES.C_TANULOID
|
||||
LEFT JOIN T_OSZTALYFONOKIERTEKELES_OSSZES OSZTALYZAT
|
||||
ON OSZTALYZAT.ID = ERTEKELES.ID
|
||||
LEFT JOIN T_DICTIONARYITEMBASE_OSSZES ERT ON ERT.ID=OSZTALYZAT.C_SZORGALOM AND ERT.C_TANEVID = @tanevId
|
||||
LEFT JOIN T_DICTIONARYITEMBASE_OSSZES JEGY ON JEGY.ID=ERTEKELES.C_OSZTALYZAT AND JEGY.C_TANEVID = @tanevId
|
||||
WHERE
|
||||
ERTEKELES.C_ERTEKELESTIPUSA = @ertekelesTipus
|
||||
AND ERTEKELES.C_TANEVID = @TanevId
|
||||
AND ERTEKELES.TOROLT='F'
|
||||
AND OSZTALYZAT.TOROLT = 'F'
|
||||
|
||||
UNION
|
||||
|
||||
SELECT
|
||||
ERTEKELES.C_TANULOID TANULOID
|
||||
, ISNULL(TARGY.C_NEVNYOMTATVANYBAN, TARGY.TARGYNEV) TARGY
|
||||
, ISNULL(ERT.C_NAME, ISNULL(ERTEKELES.C_ERTEKELESSZOVEG, CONVERT(NVARCHAR(MAX),ertekelesMegjegyzes.C_SZAZALEK)+' % ')) Ertekeles
|
||||
, ertekelesMegjegyzes.C_TEMA Jegyzet
|
||||
, ISNULL(ERT.C_NAME, ISNULL(ERTEKELES.C_ERTEKELESSZOVEG, CONVERT(NVARCHAR(MAX),ertekelesMegjegyzes.C_SZAZALEK)+' % ')) + IIF(ertekelesMegjegyzes.C_TEMA IS NULL, '', +' * '+ertekelesMegjegyzes.C_TEMA) ErtekelesJegyzettel
|
||||
, ISNULL(ERTEKELES.C_ERTEKELESSZOVEG, ERT.C_NAME) SzovegesErtekeles
|
||||
, Oraszam Oraszam
|
||||
, TARGY.KAT RENDEZ
|
||||
FROM T_TANULOERTEKELES_OSSZES ERTEKELES
|
||||
INNER JOIN @Tanulok TANCSOPORT
|
||||
ON TANCSOPORT.TanuloId = ERTEKELES.C_TANULOID
|
||||
INNER JOIN ( SELECT ID,C_NEV TARGYNEV,C_TARGYKATEGORIA KAT, C_ALTANTARGYKENTNYOMTATVANYBAN, C_FOTARGYE, C_NEVNYOMTATVANYBAN FROM T_TANTARGY_OSSZES where TOROLT = 'F') TARGY
|
||||
ON TARGY.ID = ERTEKELES.C_TANTARGYID
|
||||
LEFT JOIN T_DICTIONARYITEMBASE_OSSZES ERT ON ERT.ID=ERTEKELES.C_OSZTALYZAT AND ERT.C_TANEVID = @tanevId
|
||||
LEFT JOIN T_OSZTALYZATERTEKELES_OSSZES ertekelesMegjegyzes on ertekelesMegjegyzes.ID=ertekeles.Id
|
||||
LEFT JOIN @Oraszamok oraszam ON
|
||||
oraszam.Tantargy = ERTEKELES.C_TANTARGYID
|
||||
AND oraszam.TanuloId = ERTEKELES.C_TANULOID
|
||||
WHERE
|
||||
ERTEKELES.C_ERTEKELESTIPUSA = @ertekelesTipus
|
||||
AND ERTEKELES.C_TANEVID = @tanevId
|
||||
AND ERTEKELES.TOROLT='F'
|
||||
AND (TARGY.C_FOTARGYE = 'T' OR TARGY.C_ALTANTARGYKENTNYOMTATVANYBAN='T')
|
||||
ORDER BY TANULOID, RENDEZ
|
||||
|
||||
END
|
||||
|
||||
GO
|
@@ -0,0 +1,212 @@
|
||||
GO
|
||||
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
IF OBJECT_ID('sp_GetDokumentumMulasztasok') IS NOT NULL BEGIN
|
||||
DROP PROCEDURE [sp_GetDokumentumMulasztasok]
|
||||
END
|
||||
GO
|
||||
|
||||
-- ===========================================================================
|
||||
-- Description: Dokumentumokban használt mulasztás összesítő osztály alapján
|
||||
-- ===========================================================================
|
||||
CREATE PROCEDURE sp_GetDokumentumMulasztasok
|
||||
@osztalyId INT,
|
||||
@tanevId INT,
|
||||
@elmeletGyakorlat BIT = 0,
|
||||
@kesesTipus INT = 1499,
|
||||
@elmeletiOraPercben INT = 45,
|
||||
@gyakorlatiOraPercben INT = 60,
|
||||
@ertekelesTipus INT,
|
||||
@iskolaErdekuSzamit BIT
|
||||
AS
|
||||
BEGIN
|
||||
SET NOCOUNT ON;
|
||||
|
||||
DECLARE @Tanulok TABLE (tanuloId INT PRIMARY KEY)
|
||||
INSERT INTO @Tanulok
|
||||
SELECT TanuloId FROM fnGetDokumentumOsztalyokCsoportokTanuloi(@tanevId, @osztalyId, 'T')
|
||||
DECLARE @Idoszak INT
|
||||
DECLARE @IdoszakVege DATE
|
||||
SET @Idoszak = (SELECT
|
||||
CASE
|
||||
WHEN @ertekelesTipus = 1519 THEN 1400 --félévi
|
||||
WHEN @ertekelesTipus = 1520 THEN 1395 --év végi
|
||||
WHEN @ertekelesTipus = 1522 THEN 1403 --I. negyedévi
|
||||
WHEN @ertekelesTipus = 1523 then 1404 --III. negyedévi
|
||||
END
|
||||
)
|
||||
|
||||
SET @IdoszakVege = (SELECT C_DATUM FROM T_TANEVRENDJE_OSSZES WHERE C_NAPTIPUSA=@Idoszak AND C_TANEVID=@tanevId AND TOROLT='F')
|
||||
SELECT
|
||||
t.TANULOID tanuloid
|
||||
,m.Igazolt
|
||||
,m.Igazolatlan
|
||||
,m.ElmeletIgazolt
|
||||
,m.ElmeletIgazolatlan
|
||||
,m.GyakorlatiIgazolt
|
||||
,m.GyakorlatiIgazolatlan
|
||||
,m.Osszes
|
||||
FROM @Tanulok t
|
||||
LEFT JOIN (
|
||||
SELECT DISTINCT
|
||||
m.tanuloId
|
||||
,ISNULL(m.[hianyzasIgazoltTanoraiElmeleti], 0) + ISNULL(m.[hianyzasIgazoltTanoraiGyakorlati], 0) + ISNULL(kp.kesesIgazoltElmeletiOraban,0) + ISNULL(kp.kesesIgazoltGyakorlatiOraban,0) Igazolt
|
||||
,ISNULL(m.[hianyzasIgazolatlanTanoraiElmeleti], 0) + ISNULL(m.[hianyzasIgazolatlanTanoraiGyakorlati], 0) + ISNULL(kp.kesesIgazolatlanElmeletiOraban,0) + ISNULL(kp.kesesIgazolatlanGyakorlatiOraban,0) Igazolatlan
|
||||
,ISNULL(m.[hianyzasIgazoltTanoraiElmeleti], 0) + ISNULL(kp.kesesIgazoltElmeletiOraban,0) ElmeletIgazolt
|
||||
,ISNULL(m.[hianyzasIgazolatlanTanoraiElmeleti], 0) + ISNULL(kp.kesesIgazolatlanElmeletiOraban,0) ElmeletIgazolatlan
|
||||
,ISNULL(m.[hianyzasIgazoltTanoraiGyakorlati], 0) + ISNULL(kp.kesesIgazoltGyakorlatiOraban,0) GyakorlatiIgazolt
|
||||
,ISNULL(m.[hianyzasIgazolatlanTanoraiGyakorlati], 0) + ISNULL(kp.kesesIgazolatlanGyakorlatiOraban,0) GyakorlatiIgazolatlan
|
||||
,ISNULL(m.[hianyzasIgazoltTanoraiElmeleti], 0) + ISNULL(m.[hianyzasIgazoltTanoraiGyakorlati], 0) + ISNULL(kp.kesesIgazoltElmeletiOraban,0) + ISNULL(kp.kesesIgazoltGyakorlatiOraban,0)+
|
||||
ISNULL(m.[hianyzasIgazolatlanTanoraiElmeleti], 0) + ISNULL(m.[hianyzasIgazolatlanTanoraiGyakorlati], 0) + ISNULL(kp.kesesIgazolatlanElmeletiOraban,0) + ISNULL(kp.kesesIgazolatlanGyakorlatiOraban,0) Osszes
|
||||
FROM (
|
||||
SELECT
|
||||
tanuloId,
|
||||
[hianyzasIgazoltTanoraiElmeleti], [hianyzasIgazoltTanoraiGyakorlati],
|
||||
[hianyzasIgazolatlanTanoraiElmeleti], [hianyzasIgazolatlanTanoraiGyakorlati],
|
||||
[kesesIgazoltTanoraiElmeleti],[kesesIgazoltTanoraiGyakorlati],
|
||||
[kesesIgazolatlanTanoraiElmeleti], [kesesIgazolatlanTanoraiGyakorlati]
|
||||
FROM (
|
||||
SELECT
|
||||
x.tanuloId
|
||||
,CASE mulasztasTipus WHEN 1500 THEN 'Hianyzas' WHEN 1499 THEN 'Keses' END +
|
||||
CASE WHEN isIgazolt IS NULL THEN 'Igazolando' WHEN isIgazolt = 'T' THEN 'Igazolt' WHEN isIgazolt = 'F' THEN 'Igazolatlan' END +
|
||||
CASE isTanorai WHEN 'T' THEN 'Tanorai' WHEN 'F' THEN 'TanoranKivuli' END +
|
||||
CASE isGyakorlati WHEN 'T' THEN 'Gyakorlati' WHEN 'F' THEN 'Elmeleti' END
|
||||
AS piv
|
||||
,cnt
|
||||
FROM (
|
||||
SELECT
|
||||
m.C_ORATANULOIID AS tanuloId,
|
||||
m.C_TIPUS mulasztasTipus,
|
||||
m.C_IGAZOLT isIgazolt,
|
||||
IIF(cs.ID IS NULL OR cs.C_TIPUSA = 1034, 'T', 'F') AS isTanorai,
|
||||
IIF(t.C_GYAKORLATI='T', 'T', 'F') as isGyakorlati,
|
||||
COUNT(1) AS cnt
|
||||
FROM T_TANULOMULASZTAS_OSSZES m
|
||||
INNER JOIN T_TANITASIORA_OSSZES tn ON tn.ID = m.C_TANITASIORAKID
|
||||
INNER JOIN T_TANTARGY_OSSZES t on t.id=tn.C_TANTARGYID
|
||||
LEFT JOIN T_CSOPORT_OSSZES cs ON tn.C_OSZTALYCSOPORTID = cs.ID
|
||||
WHERE
|
||||
tn.C_DATUM <= @IdoszakVege
|
||||
AND m.C_TANEVID = @tanevId
|
||||
AND m.Torolt ='F'
|
||||
AND m.C_ORATANULOIID IN (SELECT tanuloId FROM @Tanulok)
|
||||
AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
|
||||
GROUP BY m.C_ORATANULOIID, m.C_TIPUS, m.C_IGAZOLT, IIF(cs.ID IS NULL OR cs.C_TIPUSA = 1034, 'T', 'F'), t.C_GYAKORLATI
|
||||
) x
|
||||
) p
|
||||
PIVOT (
|
||||
MAX(cnt)
|
||||
FOR piv IN (
|
||||
[hianyzasIgazoltTanoraiElmeleti], [hianyzasIgazoltTanoraiGyakorlati],
|
||||
[hianyzasIgazolatlanTanoraiElmeleti], [hianyzasIgazolatlanTanoraiGyakorlati],
|
||||
[kesesIgazoltTanoraiElmeleti],[kesesIgazoltTanoraiGyakorlati],
|
||||
[kesesIgazolatlanTanoraiElmeleti], [kesesIgazolatlanTanoraiGyakorlati])
|
||||
) AS pvt
|
||||
) m
|
||||
LEFT JOIN (
|
||||
SELECT
|
||||
tanuloId
|
||||
,[kesesIgazolandoTanoraiPerc]
|
||||
,[kesesIgazoltTanoraiPerc]
|
||||
,[kesesIgazolatlanTanoraiPerc]
|
||||
FROM (
|
||||
SELECT
|
||||
x.tanuloId
|
||||
,'Keses' +
|
||||
CASE WHEN isIgazolt IS NULL THEN 'Igazolando' WHEN isIgazolt = 'T' THEN 'Igazolt' WHEN isIgazolt = 'F' THEN 'Igazolatlan' END +
|
||||
'TanoraiPerc' AS piv
|
||||
,kesesPercben
|
||||
FROM (
|
||||
SELECT
|
||||
m.C_ORATANULOIID AS tanuloId
|
||||
,m.C_IGAZOLT isIgazolt
|
||||
,SUM(m.C_KESESPERCBEN) AS kesesPercben
|
||||
FROM T_TANULOMULASZTAS_OSSZES m
|
||||
INNER JOIN T_TANITASIORA_OSSZES tn ON tn.ID = m.C_TANITASIORAKID
|
||||
LEFT JOIN T_CSOPORT_OSSZES cs ON tn.C_OSZTALYCSOPORTID = cs.ID
|
||||
WHERE
|
||||
tn.C_DATUM <= @IdoszakVege
|
||||
AND m.C_TANEVID = @tanevId
|
||||
AND m.Torolt ='F'
|
||||
AND m.C_ORATANULOIID IN (SELECT tanuloId FROM @Tanulok)
|
||||
AND (cs.ID IS NULL OR cs.C_TIPUSA = 1034)
|
||||
AND m.C_TIPUS = 1499
|
||||
AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
|
||||
GROUP BY m.C_ORATANULOIID, m.C_IGAZOLT
|
||||
) x
|
||||
) p
|
||||
PIVOT (
|
||||
MAX(kesesPercben)
|
||||
FOR piv IN
|
||||
([kesesIgazolandoTanoraiPerc], [kesesIgazoltTanoraiPerc], [kesesIgazolatlanTanoraiPerc])
|
||||
) AS pvt
|
||||
) k ON k.tanuloId = m.tanuloId
|
||||
LEFT JOIN (
|
||||
SELECT
|
||||
tanuloId
|
||||
,SUM(kesesIgazolandoTanoraiPluszOra) kesesIgazolandoTanoraiPluszOra
|
||||
,SUM(kesesIgazoltTanoraiPluszOra) kesesIgazoltTanoraiPluszOra
|
||||
,SUM(kesesIgazolatlanTanoraiPluszOra) kesesIgazolatlanTanoraiPluszOra
|
||||
,SUM(kesesIgazoltElmeletiOraban) kesesIgazoltElmeletiOraban
|
||||
,SUM(kesesIgazolatlanElmeletiOraban) kesesIgazolatlanElmeletiOraban
|
||||
,SUM(kesesIgazoltGyakorlatiOraban) kesesIgazoltGyakorlatiOraban
|
||||
,SUM(kesesIgazolatlanGyakorlatiOraban) kesesIgazolatlanGyakorlatiOraban
|
||||
FROM (
|
||||
SELECT
|
||||
x.tanuloId
|
||||
,'Keses' +
|
||||
CASE WHEN isIgazolt IS NULL THEN 'Igazolando' WHEN isIgazolt = 'T' THEN 'Igazolt' WHEN isIgazolt = 'F' THEN 'Igazolatlan' END +
|
||||
'TanoraiPluszOra' AS piv
|
||||
,kesesOraban
|
||||
,kesesIgazoltElmeletiOraban
|
||||
,kesesIgazolatlanElmeletiOraban
|
||||
,kesesIgazoltGyakorlatiOraban
|
||||
,kesesIgazolatlanGyakorlatiOraban
|
||||
FROM (
|
||||
SELECT
|
||||
xx.tanuloId
|
||||
,xx.isIgazolt
|
||||
,SUM(xx.keses / (CASE WHEN isGyakorlati = 'F' THEN @elmeletiOraPercben ELSE @gyakorlatiOraPercben END)) AS kesesOraban
|
||||
,SUM(CASE WHEN isGyakorlati = 'F' and isIgazolt='T' THEN xx.keses / @elmeletiOraPercben ELSE 0 END) AS kesesIgazoltElmeletiOraban
|
||||
,SUM(CASE WHEN isGyakorlati = 'F' and isIgazolt='F' THEN xx.keses / @elmeletiOraPercben ELSE 0 END) AS kesesIgazolatlanElmeletiOraban
|
||||
,SUM(CASE WHEN isGyakorlati = 'T' and isIgazolt='T' THEN xx.keses / @gyakorlatiOraPercben ELSE 0 END) AS kesesIgazoltGyakorlatiOraban
|
||||
,SUM(CASE WHEN isGyakorlati = 'T' and isIgazolt='F' THEN xx.keses / @gyakorlatiOraPercben ELSE 0 END) AS kesesIgazolatlanGyakorlatiOraban
|
||||
FROM (
|
||||
SELECT
|
||||
m.C_ORATANULOIID AS tanuloId
|
||||
,m.C_IGAZOLT isIgazolt
|
||||
,t.C_GYAKORLATI AS isGyakorlati
|
||||
,SUM(m.C_KESESPERCBEN) AS keses
|
||||
FROM T_TANULOMULASZTAS_OSSZES m
|
||||
INNER JOIN T_TANITASIORA_OSSZES tn ON tn.ID = m.C_TANITASIORAKID
|
||||
INNER JOIN T_TANTARGY_OSSZES t ON t.ID = tn.C_TANTARGYID
|
||||
LEFT JOIN T_CSOPORT_OSSZES cs ON tn.C_OSZTALYCSOPORTID = cs.ID
|
||||
WHERE
|
||||
m.C_TANEVID = @tanevId
|
||||
AND m.C_ORATANULOIID IN (SELECT tanuloId FROM @Tanulok)
|
||||
AND (cs.ID IS NULL OR cs.C_TIPUSA = 1034)
|
||||
AND m.C_TIPUS = 1499
|
||||
AND m.TOROLT = 'F'
|
||||
AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
|
||||
GROUP BY m.C_ORATANULOIID, m.C_IGAZOLT, t.C_GYAKORLATI
|
||||
) xx
|
||||
GROUP BY tanuloId, xx.isIgazolt
|
||||
) x
|
||||
) p
|
||||
PIVOT (
|
||||
MAX(kesesOraban)
|
||||
FOR piv IN
|
||||
([kesesIgazolandoTanoraiPluszOra], [kesesIgazoltTanoraiPluszOra], [kesesIgazolatlanTanoraiPluszOra])
|
||||
) AS pvt
|
||||
GROUP BY tanuloId
|
||||
) kp ON m.tanuloId = kp.tanuloId
|
||||
) m on m.tanuloId=t.tanuloId
|
||||
|
||||
END
|
||||
|
||||
GO
|
@@ -0,0 +1,150 @@
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
IF OBJECT_ID('sp_GetErtesitesAltEsMulAdatok') IS NOT NULL BEGIN
|
||||
DROP PROCEDURE [sp_GetErtesitesAltEsMulAdatok]
|
||||
END
|
||||
GO
|
||||
|
||||
CREATE PROCEDURE [dbo].[sp_GetErtesitesAltEsMulAdatok]
|
||||
@pOsztalyId INT,
|
||||
@pTanevId INT,
|
||||
@pTankoteles BIT,
|
||||
@pIskolaErdekuSzamit BIT
|
||||
AS
|
||||
BEGIN
|
||||
SET NOCOUNT ON;
|
||||
|
||||
--Mulasztasok
|
||||
DECLARE @Mulasztasok TABLE (
|
||||
TanuloId INT
|
||||
,Igazolt INT
|
||||
,Igazolatlan INT
|
||||
,ElmeletIgazolt INT
|
||||
,ElmeletIgazolatlan INT
|
||||
,GyakorlatIgazolt INT
|
||||
,GyakorlatIgazolatlan INT
|
||||
,Osszes INT
|
||||
)
|
||||
|
||||
INSERT INTO @Mulasztasok
|
||||
EXEC sp_GetDokumentumMulasztasok
|
||||
@osztalyId = @pOsztalyId,
|
||||
@tanevId = @pTanevId,
|
||||
@elmeletGyakorlat = 0,
|
||||
@kesesTipus = 1499,
|
||||
@elmeletiOraPercben = 45,
|
||||
@gyakorlatiOraPercben = 60,
|
||||
@ertekelesTipus = 1520, --évvégi
|
||||
@iskolaErdekuSzamit = @pIskolaErdekuSzamit
|
||||
|
||||
--Tanulói adatok
|
||||
SELECT
|
||||
tanulo.ID,
|
||||
tanulo.C_NYOMTATASINEV TANULONEV,
|
||||
tanulo.C_ANYJANEVE ANYJANEVE,
|
||||
tanulo.C_SZULETESIHELY SZULETESIHELY,
|
||||
tanulo.C_SZULETESIDATUM SZULETESIDATUM,
|
||||
tanulo.C_NYILVANTARTASISZAM TorzslapSzam,
|
||||
AllandoLakcim.IranyitoSzam1,
|
||||
AllandoLakcim.Varos1,
|
||||
AllandoLakcim.Kozterulet1,
|
||||
AllandoLakcim.KozteruletJellege1,
|
||||
AllandoLakcim.Hazszam1,
|
||||
AllandoLakcim.Emelet1,
|
||||
AllandoLakcim.Ajto1,
|
||||
TartozkodasiHely.IranyitoSzam2,
|
||||
TartozkodasiHely.Varos2,
|
||||
TartozkodasiHely.Kozterulet2,
|
||||
TartozkodasiHely.KozteruletJellege2,
|
||||
TartozkodasiHely.Hazszam2,
|
||||
TartozkodasiHely.Emelet2,
|
||||
TartozkodasiHely.Ajto2,
|
||||
Gondviselo.GondvNeve,
|
||||
Gondviselo.GondvTelefon,
|
||||
Gondviselo.GondvCim,
|
||||
T_INTEZMENYADATOK_OSSZES.C_IGAZGATONEVE as INT_IGAZGATO_NEV,
|
||||
T_INTEZMENYADATOK_OSSZES.C_NEV as INT_NEV,
|
||||
T_INTEZMENYADATOK_OSSZES.C_OMKOD as INT_OMKOD,
|
||||
T_INTEZMENYADATOK_OSSZES.C_IRANYITOSZAM as INT_IRSZAM,
|
||||
T_INTEZMENYADATOK_OSSZES.C_VAROS as INT_VAROS,
|
||||
T_INTEZMENYADATOK_OSSZES.C_CIME as INT_CIM,
|
||||
T_INTEZMENYADATOK_OSSZES.C_IRANYITOSZAM + ' ' + T_INTEZMENYADATOK_OSSZES.C_VAROS + ' ' + T_INTEZMENYADATOK_OSSZES.C_CIME as INT_TELJES_CIM,
|
||||
T_OSZTALYCSOPORT_OSSZES.C_NEV as OSZTALYCSOPORT_NEV,
|
||||
osztf.C_VEZETEKNEV + ' ' + osztf.C_UTONEV as OSZTFO_NEV,
|
||||
ISNULL(mulasztas.Igazolt,0) IGAZOLT,
|
||||
ISNULL(mulasztas.Igazolatlan,0) IGAZOLATLAN
|
||||
FROM T_TANULOCSOPORT_OSSZES
|
||||
LEFT JOIN T_FELHASZNALO_OSSZES tanulo on tanulo.ID = T_TANULOCSOPORT_OSSZES.C_TANULOID AND tanulo.TOROLT = 'F'
|
||||
LEFT JOIN T_TANULO_OSSZES on T_TANULO_OSSZES.ID = tanulo.ID AND T_TANULO_OSSZES.TOROLT = 'F'
|
||||
LEFT JOIN T_OSZTALYCSOPORT_OSSZES on T_OSZTALYCSOPORT_OSSZES.ID = T_TANULOCSOPORT_OSSZES.C_OSZTALYCSOPORTID AND T_OSZTALYCSOPORT_OSSZES.TOROLT = 'F'
|
||||
LEFT JOIN T_INTEZMENYADATOK_OSSZES on T_INTEZMENYADATOK_OSSZES.C_INTEZMENYID = T_TANULOCSOPORT_OSSZES.C_INTEZMENYID
|
||||
AND T_INTEZMENYADATOK_OSSZES.C_TANEVID = T_TANULOCSOPORT_OSSZES.C_TANEVID
|
||||
AND T_INTEZMENYADATOK_OSSZES.TOROLT = 'F'
|
||||
LEFT JOIN T_OSZTALY_OSSZES on T_OSZTALY_OSSZES.ID = T_OSZTALYCSOPORT_OSSZES.ID AND T_OSZTALY_OSSZES.TOROLT = 'F'
|
||||
LEFT JOIN T_FELHASZNALO_OSSZES osztf on osztf.ID = T_OSZTALY_OSSZES.C_OSZTALYFONOKID AND osztf.TOROLT = 'F'
|
||||
LEFT JOIN --Állandó lakcím
|
||||
(SELECT
|
||||
T_CIM_OSSZES.C_FELHASZNALOID TanuloID,
|
||||
T_CIM_OSSZES.C_IRANYITOSZAM IranyitoSzam1,
|
||||
T_CIM_OSSZES.C_VAROS Varos1,
|
||||
T_CIM_OSSZES.C_KOZTERULET Kozterulet1,
|
||||
T_CIM_OSSZES.C_KOZTERULETJELLEGE KozteruletJellege1,
|
||||
T_CIM_OSSZES.C_HAZSZAM Hazszam1,
|
||||
T_CIM_OSSZES.C_EMELET Emelet1,
|
||||
T_CIM_OSSZES.C_AJTO Ajto1
|
||||
FROM T_CIM_OSSZES
|
||||
WHERE
|
||||
T_CIM_OSSZES.TOROLT = 'F'
|
||||
AND T_CIM_OSSZES.C_CIMTIPUSA = 907
|
||||
) AllandoLakcim ON AllandoLakcim.TanuloID = tanulo.ID
|
||||
LEFT JOIN -- Tartózkodási hely
|
||||
(SELECT
|
||||
T_CIM_OSSZES.C_FELHASZNALOID TanuloID,
|
||||
T_CIM_OSSZES.C_IRANYITOSZAM IranyitoSzam2,
|
||||
T_CIM_OSSZES.C_VAROS Varos2,
|
||||
T_CIM_OSSZES.C_KOZTERULET Kozterulet2,
|
||||
T_CIM_OSSZES.C_KOZTERULETJELLEGE KozteruletJellege2,
|
||||
T_CIM_OSSZES.C_HAZSZAM Hazszam2,
|
||||
T_CIM_OSSZES.C_EMELET Emelet2,
|
||||
T_CIM_OSSZES.C_AJTO Ajto2
|
||||
FROM T_CIM_OSSZES
|
||||
WHERE
|
||||
T_CIM_OSSZES.TOROLT = 'F'
|
||||
AND T_CIM_OSSZES.C_CIMTIPUSA = 909
|
||||
) TartozkodasiHely on TartozkodasiHely.TanuloID = tanulo.ID
|
||||
LEFT JOIN @Mulasztasok mulasztas on mulasztas.TanuloId = tanulo.ID --Mulasztások
|
||||
LEFT JOIN -- Gondviselő adatok
|
||||
(
|
||||
SELECT
|
||||
T_GONDVISELO_OSSZES.ID,
|
||||
T_GONDVISELO_OSSZES.C_TANULOID Tanulo,
|
||||
T_GONDVISELO_OSSZES.C_NEV GondvNeve,
|
||||
ISNULL(T_TELEFON_OSSZES.C_TELEFONSZAM,'') GondvTelefon,
|
||||
ISNULL(T_CIM_OSSZES.C_OSSZETETTCIM,'') GondvCim
|
||||
FROM T_GONDVISELO_OSSZES
|
||||
LEFT JOIN T_TELEFON_OSSZES on T_TELEFON_OSSZES.C_GONDVISELOID = T_GONDVISELO_OSSZES.ID and T_TELEFON_OSSZES.TOROLT = 'F'
|
||||
LEFT JOIN T_CIM_OSSZES on T_CIM_OSSZES.C_GONDVISELOID = T_GONDVISELO_OSSZES.ID and T_CIM_OSSZES.TOROLT = 'F'
|
||||
WHERE
|
||||
T_GONDVISELO_OSSZES.TOROLT = 'F'
|
||||
) Gondviselo on Gondviselo.Tanulo = T_TANULO_OSSZES.ID
|
||||
WHERE
|
||||
T_TANULOCSOPORT_OSSZES.C_OSZTALYCSOPORTID = @pOsztalyId
|
||||
AND T_TANULOCSOPORT_OSSZES.C_TANULOID IN (SELECT TanuloId FROM fnGetDokumentumOsztalyokCsoportokTanuloi(@pTanevId, @pOsztalyId, 'F'))
|
||||
AND T_TANULOCSOPORT_OSSZES.TOROLT = 'F'
|
||||
AND T_TANULO_OSSZES.C_TANKOTELEZETT = IIF(@pTankoteles = 0, 'F', 'T')
|
||||
AND T_TANULOCSOPORT_OSSZES.C_TANEVID = @pTanevId
|
||||
ORDER BY tanulo.C_NYOMTATASINEV
|
||||
|
||||
|
||||
--Mulasztások részletezése
|
||||
SELECT
|
||||
*
|
||||
FROM fnGetDokumentumMulasztasokOsztalyonkentReszletes(@pTanevId, @pOsztalyId, @pIskolaErdekuSzamit)
|
||||
WHERE
|
||||
Igazolt = 'F'
|
||||
END
|
||||
|
||||
GO
|
@@ -0,0 +1,175 @@
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
IF OBJECT_ID('[dbo].[sp_GetErtesitoNyomtatvany]') IS NOT NULL
|
||||
BEGIN
|
||||
DROP PROCEDURE [dbo].[sp_GetErtesitoNyomtatvany]
|
||||
END
|
||||
GO
|
||||
|
||||
-- =====================================================================
|
||||
-- Description: értesítõ nyomtatvány (félévi, év végi, I. negyedévi...)
|
||||
-- =====================================================================
|
||||
|
||||
CREATE PROCEDURE [dbo].[sp_GetErtesitoNyomtatvany]
|
||||
@osztalyId int,
|
||||
@tanevId int,
|
||||
@ertekelesTipus int,
|
||||
@elmeletGyakorlat bit=0,
|
||||
@kesesTipus int = 1499,
|
||||
@elmeletiOraPercben int = 45,
|
||||
@gyakorlatiOraPercben int = 60,
|
||||
@iskolaErdekuSzamit BIT
|
||||
|
||||
AS
|
||||
BEGIN
|
||||
SET NOCOUNT ON;
|
||||
|
||||
-- Fejléc
|
||||
SELECT T_INTEZMENYADATOK_OSSZES.C_NEV IntezmenyNeve,
|
||||
T_INTEZMENYADATOK_OSSZES.C_IRANYITOSZAM IntezmenyIranyitoszam,
|
||||
T_INTEZMENYADATOK_OSSZES.C_VAROS IntezmenyVaros,
|
||||
T_INTEZMENYADATOK_OSSZES.C_CIME IntezmenyCime,
|
||||
T_INTEZMENYADATOK_OSSZES.C_OMKOD OMKod,
|
||||
T_INTEZMENYADATOK_OSSZES.C_TELEFONSZAM TELEFON,
|
||||
T_INTEZMENYADATOK_OSSZES.C_EMAILCIM EMAILCIM,
|
||||
T_TANEV_OSSZES.C_NEV TANEV,
|
||||
(SELECT OFO.C_NYOMTATASINEV FROM T_OSZTALY_OSSZES
|
||||
INNER JOIN T_FELHASZNALO_OSSZES OFO
|
||||
ON OFO.ID = T_OSZTALY_OSSZES.C_OSZTALYFONOKID
|
||||
WHERE T_OSZTALY_OSSZES.ID=@osztalyId
|
||||
AND T_OSZTALY_OSSZES.TOROLT = 'F') OSZTALYFONOK,
|
||||
(SELECT to2.C_NEV FROM T_OSZTALYCSOPORT_OSSZES to2 WHERE ID = @osztalyId AND TOROLT = 'F') OSZTALYNEV,
|
||||
GETDATE() Datum
|
||||
FROM T_INTEZMENYADATOK_OSSZES
|
||||
INNER JOIN T_TANEV_OSSZES
|
||||
on T_TANEV_OSSZES.ID = T_INTEZMENYADATOK_OSSZES.C_TANEVID AND T_TANEV_OSSZES.C_INTEZMENYID = T_INTEZMENYADATOK_OSSZES.C_INTEZMENYID AND T_TANEV_OSSZES.TOROLT = 'F'
|
||||
WHERE T_INTEZMENYADATOK_OSSZES.TOROLT = 'F'
|
||||
AND T_TANEV_OSSZES.ID = @TanevId
|
||||
|
||||
-- TANULÓK
|
||||
DECLARE @Tanulok TABLE (TANULOID INT, TANULONEV NVARCHAR(MAX), OKTATASIAZONOSITO NVARCHAR(MAX), TORZSLAPSZAM NVARCHAR(MAX))
|
||||
|
||||
INSERT INTO @Tanulok
|
||||
SELECT
|
||||
tanulok.TanuloId
|
||||
,felhasznalo.C_NYOMTATASINEV
|
||||
,felhasznalo.C_OKTATASIAZONOSITO
|
||||
,felhasznalo.C_NYILVANTARTASISZAM
|
||||
FROM fnGetDokumentumOsztalyokCsoportokTanuloi(@tanevId, @osztalyId, 'T') tanulok
|
||||
INNER JOIN T_FELHASZNALO_OSSZES felhasznalo on felhasznalo.Id=tanulok.TanuloId
|
||||
|
||||
SELECT * FROM @Tanulok ORDER BY TANULONEV
|
||||
|
||||
-- ÉRTÉKELÉSEK
|
||||
DECLARE @Ertekelesek TABLE (
|
||||
TanuloId INT
|
||||
,Targy NVARCHAR(MAX)
|
||||
,Ertekeles NVARCHAR(MAX)
|
||||
,Jegyzet NVARCHAR(MAX)
|
||||
,ErtekelesJegyzettel NVARCHAR(MAX)
|
||||
,SzovegesErtekeles NVARCHAR(MAX)
|
||||
,Oraszam INT
|
||||
,RENDEZ INT
|
||||
)
|
||||
|
||||
INSERT INTO @Ertekelesek
|
||||
EXEC sp_GetDokumentumErtekelesek
|
||||
@osztalyId = @osztalyId,
|
||||
@tanevId = @tanevId,
|
||||
@ertekelesTipus = @ertekelesTipus
|
||||
|
||||
SELECT
|
||||
TanuloId
|
||||
, Targy
|
||||
, Ertekeles
|
||||
, Jegyzet
|
||||
, ErtekelesJegyzettel
|
||||
, SzovegesErtekeles
|
||||
, Oraszam
|
||||
, RENDEZ
|
||||
FROM
|
||||
@Ertekelesek
|
||||
|
||||
-- MULASZTÁSOK
|
||||
DECLARE @Mulasztasok TABLE (
|
||||
TanuloId INT
|
||||
,Igazolt INT
|
||||
,Igazolatlan INT
|
||||
,ElmeletIgazolt INT
|
||||
,ElmeletIgazolatlan INT
|
||||
,GyakorlatIgazolt INT
|
||||
,GyakorlatIgazolatlan INT
|
||||
,Osszes INT
|
||||
)
|
||||
|
||||
INSERT INTO @Mulasztasok
|
||||
EXEC sp_GetDokumentumMulasztasok
|
||||
@osztalyId = @osztalyId,
|
||||
@tanevId = @tanevId,
|
||||
@elmeletGyakorlat = @elmeletGyakorlat,
|
||||
@kesesTipus = @kesesTipus,
|
||||
@elmeletiOraPercben = @elmeletiOraPercben,
|
||||
@gyakorlatiOraPercben = @gyakorlatiOraPercben,
|
||||
@ertekelesTipus = @ertekelesTipus,
|
||||
@iskolaErdekuSzamit = @iskolaErdekuSzamit
|
||||
|
||||
SELECT
|
||||
TanuloId
|
||||
,Igazolt
|
||||
,Igazolatlan
|
||||
,ElmeletIgazolt
|
||||
,ElmeletIgazolatlan
|
||||
,GyakorlatIgazolt
|
||||
,GyakorlatIgazolatlan
|
||||
,Osszes
|
||||
FROM @Mulasztasok
|
||||
|
||||
-- TANTÁRGYI MENTESSÉGEK
|
||||
SELECT DISTINCT MENTESSEG.C_TANULOID TANULOID,
|
||||
TARGY.TARGYNEV,
|
||||
MENTESSEG.C_MENTESSEGOKA MENTESSEGOKA
|
||||
FROM T_TANULOMENTESSEG_OSSZES MENTESSEG
|
||||
INNER JOIN (SELECT ID, C_NEV TARGYNEV FROM T_TANTARGY_OSSZES WHERE TOROLT='F') TARGY
|
||||
ON TARGY.ID = MENTESSEG.C_TANTARGYID
|
||||
INNER JOIN fnGetDokumentumOsztalyokCsoportokTanuloi(@tanevId, @osztalyId, 'T') TANCSOPORT
|
||||
ON TANCSOPORT.TanuloId = MENTESSEG.C_TANULOID
|
||||
WHERE MENTESSEG.TOROLT = 'F'
|
||||
ORDER BY MENTESSEG.C_TANULOID, TARGY.TARGYNEV
|
||||
|
||||
DECLARE @EsemenyTipus INT
|
||||
SET @EsemenyTipus = (SELECT
|
||||
CASE
|
||||
WHEN @ertekelesTipus = 1519 THEN 1547 --félévi
|
||||
WHEN @ertekelesTipus = 1520 THEN 1548 --év végi
|
||||
WHEN @ertekelesTipus = 1522 THEN 1549 --I. negyedévi
|
||||
WHEN @ertekelesTipus = 1523 then 1551 --III. negyedévi
|
||||
END
|
||||
)
|
||||
|
||||
--Bejegyzések (közösségi szolgálat)
|
||||
SELECT
|
||||
bejegyzes.TanuloId TanuloId
|
||||
,Tartalom Bejegyzes
|
||||
,Tipusa Tipus
|
||||
FROM fnGetDokumentumTanulokFeljegyzesei(@tanevId, @osztalyId) bejegyzes
|
||||
WHERE
|
||||
Tipusa = 1546
|
||||
ORDER BY bejegyzes.TanuloId
|
||||
|
||||
-- Határozatok
|
||||
SELECT
|
||||
tanulok.TANULOID TANULOID
|
||||
,Tartalom BEJEGYZES
|
||||
,Tipusa TIPUS
|
||||
FROM @Tanulok tanulok
|
||||
INNER JOIN fnGetDokumentumTanulokFeljegyzesei(@tanevId, @osztalyId) esemenyek ON esemenyek.TanuloId = tanulok.TANULOID
|
||||
WHERE
|
||||
Tipusa = @EsemenyTipus
|
||||
|
||||
|
||||
END
|
||||
|
||||
GO
|
@@ -0,0 +1,402 @@
|
||||
IF OBJECT_ID('[DBO].[sp_GetNapkozisNaplo]') IS NOT NULL BEGIN
|
||||
DROP PROCEDURE [DBO].[sp_GetNapkozisNaplo]
|
||||
END
|
||||
GO
|
||||
|
||||
CREATE PROCEDURE [DBO].[sp_GetNapkozisNaplo]
|
||||
@tanevId INT
|
||||
,@intezmenyId INT
|
||||
,@csoportId INT
|
||||
,@iskolaErdekuSzamit BIT
|
||||
|
||||
AS
|
||||
BEGIN
|
||||
SET NOCOUNT ON;
|
||||
--Tanulók adatai, elérhetőségei
|
||||
DECLARE @tanulok table (
|
||||
Id int, Nev nvarchar(max), TanuloRovid nvarchar(40), Osztaly nvarchar(max), RovidNev nvarchar(30), Sorszam nvarchar(max), Torzslapszam nvarchar(max), Allampolgarsaga nvarchar(max), DiakIg nvarchar(max),
|
||||
SzulHely nvarchar(max), SzulIdo nvarchar(max), Anyja nvarchar(max), Taj nvarchar(max), OktAzon nvarchar(max), Kilepes nvarchar(max), Kepzes nvarchar(max),
|
||||
TanuloCimTipus nvarchar(max), TanuloCim nvarchar(max), TanuloTelefon nvarchar(max), TanuloEmail nvarchar(max), szoc nvarchar(max)
|
||||
)
|
||||
|
||||
INSERT INTO @tanulok
|
||||
SELECT DISTINCT
|
||||
t.id Id
|
||||
,iif(tcs.c_kilepesdatum is not null,f.c_nyomtatasinev+' (kilépett)', f.c_nyomtatasinev) as Nev
|
||||
,iif(len(f.c_nyomtatasinev)>40, SUBSTRING (f.c_nyomtatasinev, 1 , 40), f.c_nyomtatasinev)
|
||||
,Osztaly.Osztaly as Osztaly
|
||||
,iif(len(Osztaly.Osztaly)>17, SUBSTRING (Osztaly.Osztaly, 1 , 16)+'...', Osztaly.Osztaly) RovidNev
|
||||
,t.c_naplosorszam as Sorszam
|
||||
,t.c_beirasinaplosorszam as Torzslapszam
|
||||
,Allampolgarsaga.Allampolgarsaga as Allampolgarsag
|
||||
,t.c_diakigazolvanyszam as DiakIg
|
||||
,f.c_szuletesihely as SzulHely
|
||||
,FORMAT(f.c_szuletesidatum, 'yyyy. MMMM dd.', 'hu-hu') as SzulIdo
|
||||
,f.c_anyjaneve as Anyja
|
||||
,f.c_tajszam as Taj
|
||||
,f.c_oktatasiazonosito as OktAzon
|
||||
,FORMAT(tcs.c_kilepesdatum, 'yyyy. MMMM dd.', 'hu-hu') as Kilepes
|
||||
,tt.c_nev as Kepzes
|
||||
,cim.Tipus
|
||||
,cim.cim
|
||||
,tel.c_telefonszam
|
||||
,email.c_emailcim as TanuloEmail
|
||||
,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 szoc
|
||||
FROM T_TANULOCSOPORT_OSSZES tcs
|
||||
INNER JOIN T_FELHASZNALO_OSSZES f ON f.id=tcs.c_tanuloid AND f.torolt='F'
|
||||
INNER JOIN (SELECT distinct d.id Id, d.c_name Allampolgarsaga FROM T_DICTIONARYITEMBASE_OSSZES d) Allampolgarsaga ON Allampolgarsaga.Id=f.c_allampolgarsaga
|
||||
LEFT JOIN (
|
||||
SELECT tcs.c_tanuloid TanuloId, ocs.c_nev as Osztaly, tcs.c_kilepesdatum Kilepes
|
||||
FROM T_TANULOCSOPORT_OSSZES tcs
|
||||
INNER JOIN T_OSZTALY_OSSZES o ON o.id=tcs.c_osztalycsoportid
|
||||
INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs ON o.id=ocs.id
|
||||
WHERE tcs.torolt='F'
|
||||
) osztaly ON tcs.c_tanuloid=osztaly.TanuloId
|
||||
INNER JOIN T_TANTERV_OSSZES tt ON tt.c_intezmenyid=tcs.c_intezmenyid AND tt.c_intezmenyid=@intezmenyid AND tt.c_tanevid=@tanevid
|
||||
INNER JOIN T_TANULO_OSSZES t ON t.id=f.id
|
||||
INNER JOIN (
|
||||
SELECT f.id Tanulo, dt.c_name Tipus, c.c_iranyitoszam+', '+c.c_varos+' '+c.c_kozterulet+' '+dj.c_name+' '+c.c_hazszam as Cim
|
||||
FROM t_cim c
|
||||
INNER JOIN (SELECT distinct d.id, d.c_name FROM t_dictionaryitembase_osszes d )dt ON dt.id=c.c_cimtipusa
|
||||
INNER JOIN t_felhasznalo_osszes f ON f.id=c.c_felhasznaloid
|
||||
INNER JOIN (SELECT distinct d.id, d.c_name FROM t_dictionaryitembase_osszes d)dj ON dj.id=c.c_kozteruletjellege
|
||||
WHERE c.c_cimtipusa=907 AND c.c_gondviseloid is null AND c.torolt='F' AND c.c_intezmenyid=@intezmenyid)cim ON cim.Tanulo=tcs.c_tanuloid
|
||||
LEFT JOIN T_TELEFON_OSSZES tel ON tel.c_felhasznaloid=f.id AND tel.c_gondviseloid is null AND tel.torolt='F' AND tel.c_alapertelmezett='T'
|
||||
LEFT JOIN T_EMAIL_OSSZES email ON email.c_felhasznaloid=tcs.c_tanuloid AND email.c_gondviseloid is null AND email.torolt='F' AND email.c_alapertelmezett='T'
|
||||
WHERE tcs.c_osztalycsoportid=@csoportId AND tcs.c_tanevid=@tanevid AND tcs.torolt='F'
|
||||
|
||||
--Kezdőoldal
|
||||
SELECT ia.c_nev as IntezmenyNev, ia.c_cime as IntezmenyCim, ia.c_omkod as OMKOD, ia.c_igazgatoneve as IntezmenyVezeto, ocs.c_nev NapkozisCsoport, iif(len(ocs.c_nev)>17, SUBSTRING (ocs.c_nev, 1 , 17)+'...', ocs.c_nev) RovidNev,
|
||||
isnull(f.c_nyomtatasinev,'-') as CsoportVezeto, isnull(cs.c_csoportnaploleiras,'-') as CsoportNaploLeiras, FORMAT(cs.c_csoportnaplomegnyitasa, 'yyyy. MMMM dd.', 'hu-hu') as Megnyitas,
|
||||
isnull(FORMAT(cs.c_csoportnaplozarasa, 'yyyy. MMMM dd.', 'hu-hu'),'-') as Lezaras
|
||||
FROM T_INTEZMENY_OSSZES i
|
||||
INNER JOIN T_INTEZMENYADATOK_OSSZES ia ON ia.c_intezmenyid = i.id
|
||||
INNER JOIN T_OSZTALYCSOPORT_OSSZES ocs ON ocs.c_intezmenyid=i.id AND ocs.c_tanevid = @tanevid AND ocs.id = @csoportId
|
||||
INNER JOIN T_CSOPORT_OSSZES cs ON cs.id = ocs.id
|
||||
LEFT JOIN T_FELHASZNALO_OSSZES f ON f.id = cs.c_csoportvezetoid
|
||||
WHERE i.id = @intezmenyid
|
||||
AND ia.c_tanevid = @tanevid
|
||||
|
||||
--Csoportot vezette
|
||||
SELECT isnull(f.c_nyomtatasinev,'-') as CsoportVezeto FROM T_CSOPORT_OSSZES cs
|
||||
LEFT JOIN T_FELHASZNALO_OSSZES f ON f.id=cs.c_csoportvezetoid
|
||||
WHERE cs.id=@csoportId AND cs.c_altanevid=@tanevid AND cs.c_alintezmenyid=@intezmenyid
|
||||
|
||||
--Tanulók
|
||||
SELECT distinct Nev, RovidNev as Osztaly, OktAzon
|
||||
FROM @tanulok
|
||||
ORDER BY Nev
|
||||
|
||||
--Naplóhetek
|
||||
DECLARE @elsonap as date
|
||||
DECLARE @utolsonap as date
|
||||
|
||||
IF (
|
||||
SELECT c_osztalycsoportid FROM T_OSZTALYCSOPORT_TANEVRENDJE_OSSZES otr
|
||||
INNER JOIN t_tanevrendje_osszes tr ON tr.id=otr.c_tanevrendjeid AND tr.c_naptipusa=1394
|
||||
WHERE c_osztalycsoportid=@csoportid
|
||||
) IS NULL begin
|
||||
SET @elsonap= (SELECT top 1 c_datum FROM t_tanevrendje_osszes tr WHERE c_naptipusa=1394 AND c_tanevid=@tanevId AND c_intezmenyid=@intezmenyId AND torolt='F' AND c_osszescsoportravonatkozik='T')
|
||||
END
|
||||
ELSE BEGIN
|
||||
SET @elsonap = (
|
||||
SELECT top 1 tr.C_DATUM
|
||||
FROM T_OSZTALYCSOPORT_TANEVRENDJE_OSSZES otr
|
||||
INNER JOIN t_tanevrendje_osszes tr ON tr.id=otr.c_tanevrendjeid AND tr.c_naptipusa=1394
|
||||
WHERE c_osztalycsoportid=@csoportid)
|
||||
END
|
||||
|
||||
IF (
|
||||
SELECT c_osztalycsoportid
|
||||
FROM T_OSZTALYCSOPORT_TANEVRENDJE_OSSZES otr
|
||||
INNER JOIN t_tanevrendje_osszes tr ON tr.id=otr.c_tanevrendjeid AND tr.c_naptipusa=1395
|
||||
WHERE c_osztalycsoportid=@csoportId
|
||||
) IS NULL
|
||||
BEGIN
|
||||
SET @utolsonap = (SELECT top 1 c_datum FROM t_tanevrendje_osszes tr WHERE c_naptipusa=1395 AND c_tanevid=@tanevId AND c_intezmenyid=@intezmenyId AND torolt='F' AND c_osszescsoportravonatkozik='T')
|
||||
END
|
||||
ELSE BEGIN
|
||||
SET @utolsonap = (
|
||||
SELECT top 1 tr.C_DATUM
|
||||
FROM T_OSZTALYCSOPORT_TANEVRENDJE_OSSZES otr
|
||||
INNER JOIN t_tanevrendje_osszes tr ON tr.id=otr.c_tanevrendjeid AND tr.c_naptipusa=1395
|
||||
WHERE c_osztalycsoportid=@csoportId)
|
||||
END
|
||||
|
||||
SELECT
|
||||
n.c_hetsorszama as Het
|
||||
,FORMAT(convert(date,min(c_napdatuma)), 'yyyy. MMMM dd.', 'hu-hu')as HetEleje
|
||||
,FORMAT(convert(date,max(c_napdatuma)), 'yyyy. MMMM dd.', 'hu-hu') as HetVege
|
||||
FROM t_naptarinap n
|
||||
WHERE n.c_napdatuma >= @elsonap
|
||||
AND n.c_napdatuma <= @utolsonap
|
||||
AND n.c_orarendinap = 'T'
|
||||
AND n.c_tanevid = @tanevid
|
||||
AND n.c_intezmenyid = @intezmenyid
|
||||
GROUP BY n.c_hetsorszama
|
||||
|
||||
--Tanuló adatok
|
||||
SELECT * FROM @tanulok ORDER BY Nev
|
||||
|
||||
--Mulasztások
|
||||
CREATE TABLE #mulasztas (Nap int, Tanulo int, Osztaly int, MulasztasTipus int, IgazoltE nvarchar(1), IgazolasTipus int)
|
||||
INSERT INTO #mulasztas
|
||||
SELECT
|
||||
CAST(Month(tao.c_datum) as int) as Nap
|
||||
,tm.c_oratanuloiid as Tanulo
|
||||
,tao.c_osztalycsoportid as Osztaly
|
||||
,tm.c_tipus MulasztasTipus
|
||||
,tm.c_igazolt IgazoltE
|
||||
,tm.c_igazolastipusa IgazolasTipus
|
||||
FROM T_TANULOMULASZTAS_OSSZES tm
|
||||
INNER JOIN T_TANITASIORA_OSSZES tao ON tao.id=tm.c_tanitasiorakid
|
||||
AND tao.torolt='F'
|
||||
AND tao.c_tanevid = @tanevid
|
||||
AND tao.c_intezmenyid = @intezmenyid
|
||||
AND tao.c_osztalycsoportid = @csoportId
|
||||
AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
|
||||
WHERE tm.torolt = 'F'
|
||||
AND tm.c_tanevid = @tanevid
|
||||
|
||||
DECLARE @mul table(TanuloId int, Tipus nvarchar(50), TipusRendez int, [9] int, [10] int, [11] int, [12] int, [1] int, [2] int, [3] int, [4] int, [5] int, [6] int, [7] int)
|
||||
--Mulasztások
|
||||
INSERT INTO @mul
|
||||
SELECT f.id, 'mulasztások', (1),
|
||||
isnull(m.[9],0) as '9', isnull(m.[10],0) as '10', isnull(m.[11],0) as '11', isnull(m.[12],0) as '12', isnull(m.[1],0) as '1', isnull(m.[2],0) as '2', isnull(m.[3],0) as '3', isnull(m.[4],0) as '4', isnull(m.[5],0) as '5', isnull(m.[6],0) as '6', isnull(m.[7],0) as '7'
|
||||
FROM @tanulok t
|
||||
LEFT JOIN (SELECT * FROM #mulasztas m pivot (count(Osztaly) for Nap in ([1],[2],[3],[4],[5],[6],[7],[8],[9],[10],[11],[12]))pv WHERE MulasztasTipus=1500)m ON m.Tanulo=t.id
|
||||
INNER JOIN t_felhasznalo f ON f.id=t.Id
|
||||
ORDER BY f.id
|
||||
|
||||
--Ebből igazolt
|
||||
INSERT INTO @mul
|
||||
SELECT f.id, '*igazolt', (2),
|
||||
isnull(m.[9],0), isnull(m.[10],0), isnull(m.[11],0), isnull(m.[12],0), isnull(m.[1],0), isnull(m.[2],0), isnull(m.[3],0), isnull(m.[4],0), isnull(m.[5],0), isnull(m.[6],0), isnull(m.[7],0)
|
||||
FROM @tanulok t
|
||||
LEFT JOIN (SELECT * FROM #mulasztas m pivot (count(Osztaly) for Nap in ([1],[2],[3],[4],[5],[6],[7],[8],[9],[10],[11],[12]))pv WHERE IgazoltE='T' AND MulasztasTipus=1500 )m ON m.Tanulo=t.id
|
||||
INNER JOIN t_felhasznalo f ON f.id=t.Id
|
||||
ORDER BY f.id
|
||||
|
||||
--Egyéb
|
||||
INSERT INTO @mul
|
||||
SELECT f.id, '-egyéb', (3),
|
||||
/*Igazolt*/isnull(m.[9],0), isnull(m.[10],0), isnull(m.[11],0), isnull(m.[12],0), isnull(m.[1],0), isnull(m.[2],0), isnull(m.[3],0), isnull(m.[4],0), isnull(m.[5],0), isnull(m.[6],0), isnull(m.[7],0)
|
||||
FROM @tanulok t
|
||||
LEFT JOIN (SELECT * FROM #mulasztas m pivot (count(Osztaly) for Nap in ([1],[2],[3],[4],[5],[6],[7],[8],[9],[10],[11],[12]))pv WHERE IgazolasTipus=1529 AND MulasztasTipus=1500)m ON m.Tanulo=t.id
|
||||
INNER JOIN t_felhasznalo f ON f.id=t.Id
|
||||
ORDER BY f.id
|
||||
|
||||
--Orvosi igazolás
|
||||
INSERT INTO @mul
|
||||
SELECT f.id, '-orvosi ig.', (4),
|
||||
/*Igazolt*/isnull(m.[9],0), isnull(m.[10],0), isnull(m.[11],0), isnull(m.[12],0), isnull(m.[1],0), isnull(m.[2],0), isnull(m.[3],0), isnull(m.[4],0), isnull(m.[5],0), isnull(m.[6],0), isnull(m.[7],0)
|
||||
FROM @tanulok t
|
||||
LEFT JOIN (SELECT * FROM #mulasztas m pivot (count(Osztaly) for Nap in ([1],[2],[3],[4],[5],[6],[7],[8],[9],[10],[11],[12]))pv WHERE IgazolasTipus=1530 AND MulasztasTipus=1500)m ON m.Tanulo=t.id
|
||||
INNER JOIN t_felhasznalo f ON f.id=t.Id
|
||||
ORDER BY f.id
|
||||
|
||||
--Szülői
|
||||
INSERT INTO @mul
|
||||
SELECT f.id, '-szülői ig.', (5),
|
||||
/*Igazolt*/isnull(m.[9],0), isnull(m.[10],0), isnull(m.[11],0), isnull(m.[12],0), isnull(m.[1],0), isnull(m.[2],0), isnull(m.[3],0), isnull(m.[4],0), isnull(m.[5],0), isnull(m.[6],0), isnull(m.[7],0)
|
||||
FROM @tanulok t
|
||||
LEFT JOIN (SELECT * FROM #mulasztas m pivot (count(Osztaly) for Nap in ([1],[2],[3],[4],[5],[6],[7],[8],[9],[10],[11],[12]))pv WHERE IgazolasTipus=1531 AND MulasztasTipus=1500)m ON m.Tanulo=t.id
|
||||
INNER JOIN t_felhasznalo f ON f.id=t.Id
|
||||
ORDER BY f.id
|
||||
|
||||
--hivatalos távollét
|
||||
INSERT INTO @mul
|
||||
SELECT f.id, '-hivatalos t.', (6),
|
||||
/*Igazolt*/isnull(m.[9],0), isnull(m.[10],0), isnull(m.[11],0), isnull(m.[12],0), isnull(m.[1],0), isnull(m.[2],0), isnull(m.[3],0), isnull(m.[4],0), isnull(m.[5],0), isnull(m.[6],0), isnull(m.[7],0)
|
||||
FROM @tanulok t
|
||||
LEFT JOIN (SELECT * FROM #mulasztas m pivot (count(Osztaly) for Nap in ([1],[2],[3],[4],[5],[6],[7],[8],[9],[10],[11],[12]))pv WHERE IgazolasTipus=1532 AND MulasztasTipus=1500)m ON m.Tanulo=t.id
|
||||
INNER JOIN t_felhasznalo f ON f.id=t.Id
|
||||
ORDER BY f.id
|
||||
|
||||
--iskolaérdekű távollét
|
||||
IF (@iskolaErdekuSzamit = 1)
|
||||
BEGIN
|
||||
INSERT INTO @mul
|
||||
SELECT f.id, '-iskolaérdekű t.', (7),
|
||||
/*Igazolt*/isnull(m.[9],0), isnull(m.[10],0), isnull(m.[11],0), isnull(m.[12],0), isnull(m.[1],0), isnull(m.[2],0), isnull(m.[3],0), isnull(m.[4],0), isnull(m.[5],0), isnull(m.[6],0), isnull(m.[7],0)
|
||||
FROM @tanulok t
|
||||
LEFT JOIN (SELECT * FROM #mulasztas m pivot (count(Osztaly) for Nap in ([1],[2],[3],[4],[5],[6],[7],[8],[9],[10],[11],[12]))pv WHERE IgazolasTipus=1533 AND MulasztasTipus=1500)m ON m.Tanulo=t.id
|
||||
INNER JOIN t_felhasznalo f ON f.id=t.Id
|
||||
ORDER BY f.id
|
||||
END
|
||||
|
||||
--Ebből igazolatlan
|
||||
INSERT INTO @mul
|
||||
SELECT f.id, '*igazolatlan', (8),
|
||||
/*Igazolt*/isnull(m.[9],0), isnull(m.[10],0), isnull(m.[11],0), isnull(m.[12],0), isnull(m.[1],0), isnull(m.[2],0), isnull(m.[3],0), isnull(m.[4],0), isnull(m.[5],0), isnull(m.[6],0), isnull(m.[7],0)
|
||||
FROM @tanulok t
|
||||
LEFT JOIN (SELECT * FROM #mulasztas m pivot (count(Osztaly) for Nap in ([1],[2],[3],[4],[5],[6],[7],[8],[9],[10],[11],[12]))pv WHERE IgazoltE='F' AND MulasztasTipus=1500)m ON m.Tanulo=t.id
|
||||
INNER JOIN t_felhasznalo f ON f.id=t.Id
|
||||
ORDER BY f.id
|
||||
|
||||
--késés
|
||||
INSERT INTO @mul
|
||||
SELECT f.id, 'késés', (9),
|
||||
/*Igazolt*/isnull(m.[9],0), isnull(m.[10],0), isnull(m.[11],0), isnull(m.[12],0), isnull(m.[1],0), isnull(m.[2],0), isnull(m.[3],0), isnull(m.[4],0), isnull(m.[5],0), isnull(m.[6],0), isnull(m.[7],0)
|
||||
FROM @tanulok t
|
||||
LEFT JOIN (SELECT * FROM #mulasztas m pivot (count(Osztaly) for Nap in ([1],[2],[3],[4],[5],[6],[7],[8],[9],[10],[11],[12]))pv WHERE MulasztasTipus=1499)m ON m.Tanulo=t.id
|
||||
INNER JOIN t_felhasznalo f ON f.id=t.Id
|
||||
ORDER BY f.id
|
||||
|
||||
--késés igazolt
|
||||
INSERT INTO @mul
|
||||
SELECT f.id, '*igazolt', (10),
|
||||
/*Igazolt*/isnull(m.[9],0), isnull(m.[10],0), isnull(m.[11],0), isnull(m.[12],0), isnull(m.[1],0), isnull(m.[2],0), isnull(m.[3],0), isnull(m.[4],0), isnull(m.[5],0), isnull(m.[6],0), isnull(m.[7],0)
|
||||
FROM @tanulok t
|
||||
LEFT JOIN (SELECT * FROM #mulasztas m pivot (count(Osztaly) for Nap in ([1],[2],[3],[4],[5],[6],[7],[8],[9],[10],[11],[12]))pv WHERE MulasztasTipus=1499 AND IgazoltE='T')m ON m.Tanulo=t.id
|
||||
INNER JOIN t_felhasznalo f ON f.id=t.Id
|
||||
ORDER BY f.id
|
||||
|
||||
--késés igazolatlan
|
||||
INSERT INTO @mul
|
||||
SELECT f.id, '*igazolatlan', (11),
|
||||
/*Igazolt*/isnull(m.[9],0), isnull(m.[10],0), isnull(m.[11],0), isnull(m.[12],0), isnull(m.[1],0), isnull(m.[2],0), isnull(m.[3],0), isnull(m.[4],0), isnull(m.[5],0), isnull(m.[6],0), isnull(m.[7],0)
|
||||
FROM @tanulok t
|
||||
LEFT JOIN (SELECT * FROM #mulasztas m pivot (count(Osztaly) for Nap in ([1],[2],[3],[4],[5],[6],[7],[8],[9],[10],[11],[12]))pv WHERE MulasztasTipus=1499 AND IgazoltE='F')m ON m.Tanulo=t.id
|
||||
INNER JOIN t_felhasznalo f ON f.id=t.Id
|
||||
ORDER BY f.id
|
||||
|
||||
SELECT distinct *, m.[1]+m.[2]+m.[3]+m.[4]+m.[5]+m.[6]+m.[7]+m.[9]+m.[10]+m.[11]+m.[12] as Ossz FROM @mul m
|
||||
|
||||
--Napló
|
||||
SELECT distinct nn.c_hetsorszama as Het, d.Nap as Nap, FORMAT(nn.c_napdatuma, 'yyyy. MMMM dd.', 'hu-hu') as Datum FROM T_NAPTARINAP_OSSZES nn
|
||||
LEFT JOIN T_TANITASIORA_OSSZES tao ON tao.c_datum=nn.c_napdatuma AND tao.c_osztalycsoportid=@csoportid AND tao.torolt='F'
|
||||
LEFT JOIN (SELECT distinct d.id as ID, d.c_name Nap FROM T_DICTIONARYITEMBASE_OSSZES d) d ON d.id=nn.c_hetnapja
|
||||
LEFT JOIN T_FOGLALKOZAS_OSSZES fog ON fog.id=tao.c_foglalkozasid AND fog.c_tanevid=@tanevid
|
||||
LEFT JOIN T_FOGLALKOZASOK_TANAROK_OSSZES ft ON ft.c_foglalkozasokid=fog.id
|
||||
LEFT JOIN T_FELHASZNALO_OSSZES f ON f.id=ft.c_tanarokid AND f.torolt='F'
|
||||
WHERE nn.c_orarendinap='T' AND nn.c_napdatuma>=@elsonap AND nn.c_napdatuma<=@utolsonap
|
||||
ORDER BY nn.c_hetsorszama,FORMAT(nn.c_napdatuma, 'yyyy. MMMM dd.', 'hu-hu')
|
||||
|
||||
--Napló adatok
|
||||
DECLARE @Orak TABLE (datum date, Sorszam int, Hetsorszam int)
|
||||
INSERT INTO @Orak
|
||||
SELECT DISTINCT convert(date, n.c_napdatuma) datum, sz.Oraszam, n.c_hetsorszama
|
||||
FROM T_NAPTARINAP_OSSZES n
|
||||
CROSS JOIN (VALUES (1),(2),(3),(4),(5),(6),(7),(8),(9),(10)) sz (Oraszam)
|
||||
WHERE n.c_napdatuma>=@elsonap AND n.c_napdatuma<=@utolsonap AND n.c_orarendinap='T' AND n.c_intezmenyId=@intezmenyId
|
||||
|
||||
|
||||
DECLARE @oraSorszam TABLE (Id int, EvesSorszam int)
|
||||
INSERT INTO @oraSorszam (Id, EvesSorszam)
|
||||
SELECT DISTINCT
|
||||
s.Id
|
||||
,s.EvesSorszam
|
||||
FROM (
|
||||
SELECT DISTINCT tn.C_TANTARGYID, tn.C_OSZTALYCSOPORTID, ot.C_TANAROKID, tn.C_INTEZMENYID--, fh.C_NYOMTATASINEV
|
||||
FROM T_TANITASIORA_OSSZES tn
|
||||
INNER JOIN T_ORAK_TANAROK ot ON tn.ID = ot.C_ORAKID
|
||||
INNER JOIN T_FELHASZNALO fh ON fh.ID = ot.C_TANAROKID
|
||||
WHERE tn.C_OSZTALYCSOPORTID = @csoportid
|
||||
) x
|
||||
CROSS APPLY dbo.fnGetEvesOraszamLista (
|
||||
x.C_TANTARGYID
|
||||
,x.C_OSZTALYCSOPORTID
|
||||
,x.C_TANAROKID
|
||||
,GETDATE()
|
||||
,x.C_INTEZMENYID
|
||||
,@tanevID
|
||||
) s
|
||||
|
||||
SELECT DISTINCT
|
||||
o.Hetsorszam as Het
|
||||
,o.Sorszam as Oraszam
|
||||
,FORMAT(o.Datum, 'yyyy. MMMM dd.', 'hu-hu') as Datum
|
||||
,CONVERT(nvarchar(max), DATEPART(hour,tao.c_orakezdete)) + ':' + CONVERT(nvarchar(max)
|
||||
,DATEPART(minute,tao.c_orakezdete)) as OraKezd
|
||||
,f.c_nyomtatasinev as Tanar
|
||||
,s.EvesSorszam as Sorszam
|
||||
,tao.c_tema as Tema
|
||||
FROM @Orak o
|
||||
LEFT JOIN T_TANITASIORA_OSSZES tao ON tao.c_datum = o.Datum
|
||||
AND tao.c_osztalycsoportid = @csoportid
|
||||
AND tao.torolt = 'F'
|
||||
AND tao.c_oraszam = o.Sorszam
|
||||
AND tao.c_tanevid = @tanevid
|
||||
LEFT JOIN @oraSorszam s ON s.Id = tao.ID
|
||||
LEFT JOIN T_NAPTARINAP_OSSZES nn ON nn.c_napdatuma = o.Datum AND nn.c_tanevid = @tanevid
|
||||
LEFT JOIN (SELECT distinct d.id as ID, d.c_name Nap FROM t_dictionaryitembase_osszes d) d ON d.id=nn.c_hetnapja
|
||||
LEFT JOIN T_FOGLALKOZAS_OSSZES fog ON fog.id = tao.c_foglalkozasid AND fog.torolt = 'F'
|
||||
LEFT JOIN T_FOGLALKOZASOK_TANAROK_OSSZES ft ON ft.c_foglalkozasokid = fog.id
|
||||
LEFT JOIN T_FELHASZNALO_OSSZES f ON f.id = ft.c_tanarokid AND f.torolt = 'F'
|
||||
ORDER BY Oraszam
|
||||
|
||||
|
||||
--Napló mulasztás
|
||||
SELECT C_HETSORSZAMA Het, C_NYOMTATASINEV Tanulo,
|
||||
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 t_osztalycsoport ocs ON ocs.id=@csoportid
|
||||
WHERE n.C_NAPTARINAPID = o.C_NAPTARINAPID
|
||||
AND m.C_ORATANULOIID = tm.C_ORATANULOIID
|
||||
AND o.C_TANEVID = @tanevID
|
||||
AND tm.C_TANEVID = @tanevID
|
||||
AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
|
||||
AND tm.TOROLT='F'
|
||||
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
|
||||
INNER JOIN T_FELHASZNALO_OSSZES t ON t.ID = m.C_ORATANULOIID
|
||||
WHERE
|
||||
n.C_TANEVID = @tanevID
|
||||
AND m.C_TANEVID = @tanevID
|
||||
AND n.c_osztalycsoportid=@csoportId
|
||||
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
|
||||
|
||||
--Tanuló feljegyzései
|
||||
SELECT
|
||||
feljegyzes.TanuloId AS Tanulo
|
||||
,FORMAT(Datum, 'yyyy.MM.dd.') AS Idopont
|
||||
,d.C_NAME AS Tipus
|
||||
,Tartalom AS Feljegyzes
|
||||
,FeljegyzoNeve AS Feljegyzo
|
||||
FROM fnGetDokumentumTanulokFeljegyzesei(@tanevId, @csoportId) feljegyzes
|
||||
INNER JOIN T_DICTIONARYITEMBASE_OSSZES d ON d.ID=Tipusa AND d.C_TANEVID = @tanevId
|
||||
WHERE Tipusa <> 1534
|
||||
|
||||
--Tanuló gondviselői
|
||||
SELECT 'Gondviselő ('+Rokonsag.Rokonsag+'):' as Fejlec, tcs.c_tanuloid Tanulo, g.c_nev Gondviselo, gcim.Tipus Tipus,gcim.Cim as Cim, gtel.c_telefonszam Telefon, gemail.C_EMAILCIM Email
|
||||
FROM T_TANULOCSOPORT_OSSZES tcs
|
||||
INNER JOIN T_GONDVISELO_OSSZES g ON g.c_tanuloid=tcs.c_tanuloid AND g.torolt='F'
|
||||
LEFT JOIN (
|
||||
SELECT g.id Gondviselo, dt.c_name Tipus, c.c_iranyitoszam+', '+c.c_varos+' '+c.c_kozterulet+' '+dj.c_name+' '+c.c_hazszam as Cim
|
||||
FROM T_CIM_OSSZES c
|
||||
INNER JOIN (SELECT distinct d.id, d.c_name FROM T_DICTIONARYITEMBASE_OSSZES d )dt ON dt.id=c.c_cimtipusa
|
||||
INNER JOIN t_gondviselo_osszes g ON g.id=c.c_gondviseloid AND g.torolt='F'
|
||||
INNER JOIN (SELECT distinct d.id, d.c_name FROM T_DICTIONARYITEMBASE_OSSZES d )dj ON dj.id=c.c_kozteruletjellege
|
||||
)gcim ON gcim.Gondviselo=g.id
|
||||
LEFT JOIN T_TELEFON_OSSZES gtel ON gtel.c_gondviseloid=g.id AND gtel.torolt='F'
|
||||
LEFT JOIN T_EMAIL_OSSZES gemail ON gemail.c_gondviseloid=g.id AND gemail.torolt='F'
|
||||
LEFT JOIN (SELECT distinct d.id Id, d.c_name Rokonsag FROM T_DICTIONARYITEMBASE_OSSZES d) Rokonsag ON Rokonsag.Id=g.c_rokonsagfoka
|
||||
WHERE tcs.c_osztalycsoportid=@csoportId AND tcs.c_tanevid=@tanevid AND tcs.torolt='F'
|
||||
|
||||
DROP TABLE #MULASZTAS
|
||||
END
|
||||
GO
|
||||
|
@@ -0,0 +1,902 @@
|
||||
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
|
||||
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
|
||||
CONVERT(NVARCHAR(100)
|
||||
,DATEPART(YEAR, T_ORALATOGATAS_OSSZES.C_DATUM))+'. '+CONVERT(NVARCHAR(100), DATEPART(MONTH, T_ORALATOGATAS_OSSZES.C_DATUM))+'. '+
|
||||
CONVERT(NVARCHAR(100), DATEPART(DAY, T_ORALATOGATAS_OSSZES.C_DATUM))+'. ' 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
|
||||
convert(nvarchar(100), datepart(year, C_ELLENORZESDATUMA))+'. '+convert(nvarchar(100), datepart(month, C_ELLENORZESDATUMA))+'. '+
|
||||
convert(nvarchar(100), datepart(day, C_ELLENORZESDATUMA))+'. '+convert(nvarchar(100), datepart(hour, C_ELLENORZESDATUMA))+':'+
|
||||
convert(nvarchar(100), datepart(minute, C_ELLENORZESDATUMA)) 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 @TenylegesOrak TABLE (
|
||||
HetirendID int,
|
||||
HetNapja int,
|
||||
Oraszam int,
|
||||
Targyid int,
|
||||
Targy nvarchar(max),
|
||||
Terem nvarchar(max),
|
||||
Tanar nvarchar(max)
|
||||
)
|
||||
INSERT INTO @TenylegesOrak
|
||||
SELECT o.C_HETIREND AS HetiRend, o.C_HETNAPJA HetNapja, o.C_ORASZAM Oraszam, t.ID, ISNULL(t.C_NEVNYOMTATVANYBAN, t.C_NEV) TargyNev, tm.C_NEV Terem,
|
||||
(SELECT TOP 1 tanar.C_NYOMTATASINEV
|
||||
FROM T_FELHASZNALO_OSSZES tanar
|
||||
INNER JOIN T_FOGLALKOZASOK_TANAROK_OSSZES ft ON tanar.ID = ft.C_TANAROKID
|
||||
WHERE ft.C_FOGLALKOZASOKID = f.ID ) TanarNev
|
||||
FROM T_ORARENDIORA_OSSZES o
|
||||
INNER JOIN T_FOGLALKOZAS_OSSZES f ON f.ID = o.C_FOGLALKOZASID
|
||||
INNER JOIN #osztalycsoportok ocs ON f.C_OSZTALYCSOPORTID = ocs.OsztalyCsoportId
|
||||
INNER JOIN T_TANTARGY_OSSZES t ON t.ID = f.C_TANTARGYID
|
||||
LEFT JOIN T_TEREM_OSSZES tm ON tm.ID = o.C_TEREMID
|
||||
WHERE o.TOROLT = 'F' and o.torolt='F' and o.c_tanevId=@tanevId
|
||||
|
||||
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)
|
||||
|
||||
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
|
||||
|
||||
IF @isSzövegesNaplo = 0 BEGIN /* NORMÁL OSZTÁLYNAPLÓ */
|
||||
DECLARE @prepare nvarchar(MAX),
|
||||
@orarendSql nvarchar(MAX),
|
||||
@mulasztasSql nvarchar(MAX),
|
||||
@superSql nvarchar(MAX)
|
||||
|
||||
SET @prepare = '
|
||||
DECLARE @oraszam TABLE (oraszam int primary key);
|
||||
|
||||
INSERT INTO @oraszam (oraszam)
|
||||
VALUES (1),(2),(3),(4),(5),(6),(7),(8),(9),(10);
|
||||
|
||||
DECLARE @hianyzasTmp TABLE (naptarinap int, hianyzas nvarchar(4000))
|
||||
|
||||
INSERT INTO @hianyzasTmp
|
||||
SELECT DISTINCT
|
||||
n.C_NAPTARINAPID
|
||||
, t.C_NYOMTATASINEV + '' ['' + 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
|
||||
WHERE
|
||||
n.C_NAPTARINAPID = o.C_NAPTARINAPID
|
||||
AND m.C_ORATANULOIID = tm.C_ORATANULOIID
|
||||
AND tm.TOROLT = ''F''
|
||||
AND tm.c_tanevId=@tanevId
|
||||
AND tm.c_oratanuloiid in (SELECT C_TANULOID FROM T_TANULOCSOPORT_OSSZES WHERE C_OSZTALYCSOPORTID=@osztaly AND TOROLT=''F'')
|
||||
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
|
||||
INNER JOIN #osztalycsoportok cs ON cs.OsztalyCsoportId = n.C_OSZTALYCSOPORTID
|
||||
INNER JOIN T_FELHASZNALO_OSSZES t ON t.ID = m.C_ORATANULOIID
|
||||
WHERE
|
||||
m.TOROLT = ''F''
|
||||
AND m.c_intezmenyId=@intezmenyId
|
||||
AND m.c_tanevId=@tanevId
|
||||
AND n.C_OSZTALYCSOPORTID in (SELECT ID FROM #OsztalyVagyTanoraiCsoport)
|
||||
AND (@iskolaErdekuSzamit = 1 OR C_IGAZOLASTIPUSA <> 1533)
|
||||
GROUP BY n.C_NAPTARINAPID, C_ORATANULOIID, C_NYOMTATASINEV
|
||||
'
|
||||
|
||||
SET @orarendSql = '
|
||||
SELECT * FROM (
|
||||
SELECT n.ID AS T1ID, IIF(n.C_ORARENDINAP = ''T'', DENSE_RANK() OVER(PARTITION BY n.C_TANEVID, n.C_ORARENDINAP ORDER BY n.C_NAPDATUMA), NULL) AS NAPSZAM, n.C_NAPDATUMA, n.C_HETSORSZAMA, sz.ORASZAM, n.C_HETNAPJA, o.tantargyak AS TANTARGY
|
||||
FROM T_NAPTARINAP_OSSZES n
|
||||
CROSS JOIN @oraszam sz
|
||||
LEFT JOIN (
|
||||
SELECT t.C_NAPTARINAPID, t.C_ORASZAM,
|
||||
STUFF((
|
||||
SELECT DISTINCT '' | '' + ISNULL(tt.C_NEVNYOMTATVANYBAN, tt.C_NEV)
|
||||
FROM T_TANITASIORA_OSSZES t2
|
||||
INNER JOIN T_FOGLALKOZAS_OSSZES f ON t2.C_FOGLALKOZASID = f.ID
|
||||
INNER JOIN T_TANTARGY_OSSZES tt ON tt.ID = f.C_TANTARGYID
|
||||
INNER JOIN #osztalycsoportok cs ON t2.C_OSZTALYCSOPORTID = cs.OsztalyCsoportId
|
||||
WHERE t.C_NAPTARINAPID = t2.C_NAPTARINAPID
|
||||
AND t.C_ORASZAM = t2.C_ORASZAM
|
||||
FOR XML PATH(''''), TYPE).value(''.'', ''varchar(max)''),1,3,'''') AS tantargyak
|
||||
FROM T_TANITASIORA_OSSZES t
|
||||
INNER JOIN #osztalycsoportok cs ON t.C_OSZTALYCSOPORTID = cs.OsztalyCsoportId
|
||||
GROUP BY t.C_NAPTARINAPID, t.C_ORASZAM
|
||||
) o ON o.C_NAPTARINAPID = n.ID AND o.C_ORASZAM = sz.oraszam
|
||||
INNER JOIN T_TANEV_OSSZES te ON n.C_TANEVID = te.ID
|
||||
WHERE
|
||||
te.id=@tanevId and te.torolt=''F'' and te.c_intezmenyId=@intezmenyId
|
||||
AND n.C_NAPDATUMA BETWEEN te.C_ELSOTANITASINAP AND te.C_UTOLSOTANITASINAP
|
||||
AND (n.C_HETNAPJA BETWEEN 1408 AND 1412 OR n.C_ORARENDINAP = ''T'')
|
||||
AND n.TOROLT = ''F''
|
||||
) T1
|
||||
LEFT JOIN (
|
||||
SELECT DISTINCT n.ID AS T2ID,
|
||||
tr.C_MEGJEGYZES AS [Megjegyzés],
|
||||
STUFF((
|
||||
SELECT char(13) + char(10) + hianyzas
|
||||
FROM @hianyzasTmp tbl
|
||||
WHERE tbl.naptarinap = nn.naptarinap
|
||||
FOR XML PATH(''''), TYPE).value(''.'', ''varchar(max)''),2,1,'''') AS MULASZTAS
|
||||
FROM T_NAPTARINAP_OSSZES n
|
||||
LEFT JOIN @hianyzasTmp nn ON n.ID = nn.naptarinap
|
||||
LEFT JOIN T_TANEVRENDJE_OSSZES tr ON tr.C_DATUM = n.C_NAPDATUMA
|
||||
INNER JOIN T_TANEV_OSSZES te ON te.ID = n.C_TANEVID AND te.TOROLT = ''F'' AND te.id=@tanevId
|
||||
WHERE n.TOROLT = ''F'' AND (tr.TOROLT = ''F'' OR tr.TOROLT IS NULL)
|
||||
) T2 ON T1.T1ID = T2.T2ID AND T1.ORASZAM = 1
|
||||
'
|
||||
|
||||
DECLARE @selectList nvarchar(MAX),
|
||||
@pivotList nvarchar(MAX),
|
||||
@sql nvarchar(MAX)
|
||||
SELECT @pivotList = ISNULL(@pivotList + ', ', '') + '[' + CAST(t.Targyid AS varchar(6)) + ']',
|
||||
@selectList = ISNULL(@selectList + ', ', '') + '[' + CAST(t.Targyid AS varchar(6)) + '] AS [' + t.Targy + ']'
|
||||
FROM (
|
||||
SELECT DISTINCT Targyid, Targy/* + '(' + Tanar + ')' AS Targy*/ FROM @TenylegesOrak) t
|
||||
|
||||
SET @sql = ' LEFT JOIN ( SELECT T3ID, ' + @selectList + '
|
||||
FROM (
|
||||
SELECT o.C_NAPTARINAPID AS T3ID, o.C_TANTARGYID,
|
||||
STUFF((
|
||||
SELECT '', '' +convert(nvarchar(max),isnull(oes.OraSorszam, ''-'')) + ''.: '' + C_TEMA
|
||||
FROM T_TANITASIORA_OSSZES oo
|
||||
INNER JOIN #osztalycsoportok cs ON cs.OsztalyCsoportId = oo.C_OSZTALYCSOPORTID
|
||||
left JOIN #OraSorszam oes on oes.TanitasioraId=oo.Id
|
||||
WHERE o.C_NAPTARINAPID = oo.C_NAPTARINAPID
|
||||
AND o.C_TANTARGYID = oo.C_TANTARGYID
|
||||
AND oo.TOROLT = ''F''
|
||||
ORDER BY oo.ID --oo.C_ORAEVESSORSZAM
|
||||
FOR XML PATH(''''), TYPE).value(''.'', ''varchar(max)'')
|
||||
,1,2,'' '') AS tema
|
||||
FROM T_TANITASIORA_OSSZES o
|
||||
LEFT JOIN T_NAPTARINAP_OSSZES n ON o.C_NAPTARINAPID = n.ID
|
||||
LEFT JOIN T_TANEV_OSSZES te ON n.C_TANEVID = te.ID
|
||||
WHERE te.id=@tanevId
|
||||
AND n.C_NAPDATUMA BETWEEN te.C_ELSOTANITASINAP AND te.C_UTOLSOTANITASINAP
|
||||
AND n.C_ORARENDINAP = ''T''
|
||||
AND n.TOROLT = ''F'' and n.c_intezmenyId=@intezmenyId and n.c_tanevId=@tanevId
|
||||
AND o.C_OSZTALYCSOPORTID IN (SELECT OsztalyCsoportId FROM #osztalycsoportok)
|
||||
AND (o.TOROLT = ''F'' OR o.TOROLT IS NULL)
|
||||
GROUP BY o.C_NAPTARINAPID, o.C_TANTARGYID )p
|
||||
PIVOT
|
||||
(
|
||||
MAX(tema)
|
||||
FOR C_TANTARGYID IN (' + @pivotList + ')
|
||||
) AS pvt'
|
||||
|
||||
SET @superSql = @orarendSql + ISNULL(@sql + '
|
||||
) T3 ON T1.T1ID = T3.T3ID AND T1.ORASZAM = 1', '') + '
|
||||
ORDER BY T1.T1ID, T1.C_HETNAPJA, T1.ORASZAM'
|
||||
|
||||
SET @superSql = @prepare + @superSql
|
||||
EXEC sp_executesql @superSql, N'@osztaly INT, @intezmenyId INT, @tanevId INT, @iskolaErdekuSzamit BIT', @osztalyId, @intezmenyId, @tanevId, @iskolaErdekuSzamit
|
||||
END -- NORMÁL OSZTÁLYNAPLÓ
|
||||
|
||||
ELSE BEGIN -- SZÖVEGES OSZTÁLYNAPLÓ
|
||||
SELECT nn.C_NAPDATUMA
|
||||
, FORMAT(C_NAPDATUMA, 'dddd', 'hu-hu') AS NAPNEVE
|
||||
, tr.C_MEGJEGYZES
|
||||
, nh.C_HETKEZDONAPJA
|
||||
, nh.C_HETUTOLSONAPJA
|
||||
, nn.C_HETSORSZAMA
|
||||
, sorszam AS ORASORSZAM,
|
||||
IIF(nn.C_ORARENDINAP = 'T', DENSE_RANK() OVER(PARTITION BY nn.C_TANEVID, nn.C_ORARENDINAP ORDER BY nn.C_NAPDATUMA), NULL) AS NAPSZAM
|
||||
, ISNULL(tt.C_NEVNYOMTATVANYBAN, tt.C_NEV) AS TANTARGY
|
||||
, ISNULL(ht.C_NYOMTATASINEV
|
||||
, at.C_NYOMTATASINEV) AS TANAR
|
||||
, o.C_TEMA ORAANYAGA
|
||||
, IIF(o.C_SORSZAMOZANDO = 'F', '-', CAST(oes.OraSorszam AS VARCHAR(MAX))) AS C_ORAEVESSORSZAM
|
||||
INTO #szoveges
|
||||
FROM T_NAPTARINAP_OSSZES nn
|
||||
CROSS JOIN (VALUES (1),(2),(3),(4),(5),(6),(7),(8),(9),(10), (11), (12)) sz (sorszam)
|
||||
INNER JOIN T_NAPTARIHET_OSSZES nh ON nn.C_NAPDATUMA BETWEEN nh.C_HETKEZDONAPJA AND nh.C_HETUTOLSONAPJA AND nh.C_TANEVID = @tanevId and nh.torolt='F'
|
||||
LEFT JOIN T_TANITASIORA_OSSZES o ON o.C_DATUM = nn.C_NAPDATUMA AND sz.sorszam = o.C_ORASZAM AND o.C_TANEVID = @tanevId and o.torolt='F' AND (o.C_OSZTALYCSOPORTID IN (SELECT OsztalyCsoportId FROM #osztalycsoportok))
|
||||
LEFT JOIN #OraSorszam oes on oes.TanitasioraId=o.id
|
||||
LEFT JOIN T_FOGLALKOZAS_OSSZES f ON f.ID = o.C_FOGLALKOZASID AND f.C_TANEVID = @tanevId and f.torolt='F'
|
||||
LEFT JOIN T_TANTARGY_OSSZES tt ON tt.ID = o.C_TANTARGYID
|
||||
LEFT JOIN T_FELHASZNALO_OSSZES ht ON o.C_HELYETTESITOTANARID = ht.ID AND ht.C_TANEVID = @tanevId
|
||||
LEFT JOIN T_FOGLALKOZASOK_TANAROK ft ON f.ID = ft.C_FOGLALKOZASOKID
|
||||
LEFT JOIN T_FELHASZNALO_OSSZES at ON ft.C_TANAROKID = at.ID
|
||||
LEFT JOIN T_TANEVRENDJE_OSSZES tr ON tr.C_DATUM = nn.C_NAPDATUMA AND tr.C_TANEVID = @tanevId and tr.torolt='F' and tr.c_intezmenyId=@intezmenyId
|
||||
WHERE
|
||||
nn.C_HETNAPJA BETWEEN 1408 AND 1412 /* Hétfő - Péntek */
|
||||
AND nn.C_TANEVID = @tanevId
|
||||
AND nn.torolt='F'
|
||||
ORDER BY nn.C_NAPDATUMA, sorszam, tt.c_nev
|
||||
|
||||
select distinct c_napdatuma
|
||||
, napneve
|
||||
, c_megjegyzes
|
||||
, c_hetkezdonapja
|
||||
, c_hetutolsonapja
|
||||
, c_hetsorszama
|
||||
, orasorszam
|
||||
, napszam
|
||||
, STUFF((SELECT ' | ' + 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,2,' ') TANTARGY
|
||||
, STUFF((SELECT ' | ' + 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,2,' ') TANAR
|
||||
, STUFF((SELECT ' | ' + 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,2,' ') ORAANYAGA
|
||||
, STUFF((SELECT ' | ' + 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,2,' ') OraEvesSorszama
|
||||
from #szoveges szov
|
||||
order by C_NAPDATUMA, orasorszam
|
||||
drop table #OraSorszam
|
||||
drop table #szoveges
|
||||
|
||||
|
||||
/*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
|
||||
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
|
||||
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
|
||||
) 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
|
||||
, ISNULL(t.C_NEVNYOMTATVANYBAN, 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*/
|
||||
SET @pivotList = null;
|
||||
SET @selectList = null;
|
||||
SET @sql = null;
|
||||
DECLARE @columnList nvarchar(max);
|
||||
|
||||
SELECT
|
||||
@pivotList = ISNULL(@pivotList + ', ', '') + '[' + CAST(t.Targyid AS varchar(6)) + ']',
|
||||
@selectList = ISNULL(@selectList + ', ', '') + '[' + CAST(t.Targyid AS varchar(6)) + '] AS [' + t.Targy + ']',
|
||||
@columnList = ISNULL(@columnList + ', ', '') + '[' + CAST(t.Targyid AS varchar(6)) + '] nvarchar(250) '
|
||||
FROM (
|
||||
SELECT DISTINCT Targyid, Targy FROM @TenylegesOrak) 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
|
||||
|
||||
|
||||
/* 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
|
||||
, ISNULL(t.C_NEVNYOMTATVANYBAN, 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 #osztalycsoportok
|
||||
DROP TABLE #OsztalyVagyTanoraiCsoport
|
||||
|
||||
END
|
||||
|
||||
GO
|
@@ -0,0 +1,178 @@
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
IF OBJECT_ID('[dbo].[sp_GetSzakmaiGyNaplo]') IS NOT NULL
|
||||
BEGIN
|
||||
DROP PROCEDURE [dbo].[sp_GetSzakmaiGyNaplo]
|
||||
END
|
||||
GO
|
||||
|
||||
CREATE PROCEDURE [dbo].[sp_GetSzakmaiGyNaplo]
|
||||
@tanevId INT,
|
||||
@intezmenyId INT,
|
||||
@csoportId INT,
|
||||
@iskolaErdekuSzamit BIT
|
||||
|
||||
AS
|
||||
BEGIN
|
||||
SET NOCOUNT ON;
|
||||
|
||||
--Kezdőoldal
|
||||
select ia.c_nev as IntezmenyNev, convert(nvarchar(5), ia.c_iranyitoszam)+', '+ia.c_varos+', '+ia.c_cime as IntezmenyCim, ia.c_omkod as OMKOD, ia.c_igazgatoneve as IntezmenyVezeto, ocs.c_nev NapkozisCsoport,
|
||||
isnull(f.c_nyomtatasinev,'-') as CsoportVezeto, isnull(cs.c_csoportnaploleiras,'-') as CsoportNaploLeiras, FORMAT(cs.c_csoportnaplomegnyitasa, 'yyyy. MMMM dd.', 'hu-hu') as Megnyitas,
|
||||
isnull(FORMAT(cs.c_csoportnaplozarasa, 'yyyy. MMMM dd.', 'hu-hu'),'-') as Lezaras, t.c_nev as Tanev, cs.c_csoportnaploleiras as Megjegyzes
|
||||
from T_INTEZMENY_OSSZES i
|
||||
inner join T_INTEZMENYADATOK_OSSZES ia on ia.c_intezmenyid=i.id
|
||||
inner join T_OSZTALYCSOPORT_OSSZES ocs on ocs.c_intezmenyid=i.id
|
||||
inner join T_CSOPORT_OSSZES cs on cs.id=ocs.id
|
||||
left join T_FELHASZNALO_OSSZES f on f.id=cs.c_csoportvezetoid
|
||||
inner join T_TANEV_OSSZES t on t.id=ia.c_tanevid
|
||||
where i.id=@intezmenyid and ia.c_tanevid=@tanevid and ocs.id=@csoportId
|
||||
|
||||
--Csoport tanulóinak osztályai
|
||||
select Osztaly.Osztaly, count(c_tanuloid) Tanulo from t_tanulocsoport tcs
|
||||
inner join (select tcs.c_tanuloid Tanulo, ocs.c_nev as Osztaly, tcs.c_kilepesdatum Kilepes from T_TANULOCSOPORT_OSSZES tcs
|
||||
inner join T_OSZTALY_OSSZES o on o.id=tcs.c_osztalycsoportid and o.torolt='F'
|
||||
inner join T_OSZTALYCSOPORT_OSSZES ocs on o.id=ocs.id
|
||||
where tcs.c_kilepesdatum is null and tcs.c_intezmenyid=@intezmenyid and tcs.c_tanevid=@tanevid) osztaly on osztaly.Tanulo=tcs.c_tanuloid and tcs.TOROLT='F'
|
||||
where tcs.c_osztalycsoportid=@csoportId
|
||||
group by osztaly.Osztaly
|
||||
|
||||
DECLARE @tanulo TABLE (Tanulo int, Osztaly nvarchar(max), RovidNev nvarchar(max))
|
||||
insert into @tanulo
|
||||
select f.id as Tanulo, Osztaly.Osztaly, Osztaly.Osztaly RovidNev from T_TANULOCSOPORT_OSSZES tcs
|
||||
inner join (select tcs.c_tanuloid Tanulo, ocs.c_nev Osztaly from t_tanulocsoport tcs
|
||||
inner join t_osztaly o on o.id=tcs.c_osztalycsoportid and o.torolt='F'
|
||||
inner join t_osztalycsoport ocs on ocs.id=tcs.c_osztalycsoportid
|
||||
where tcs.c_kilepesdatum is null and tcs.c_tanevid=@tanevid) Osztaly on Osztaly.Tanulo=tcs.c_tanuloid and tcs.TOROLT='F'
|
||||
inner join t_felhasznalo f on f.id=tcs.c_tanuloid
|
||||
where tcs.c_osztalycsoportid=@csoportId
|
||||
|
||||
declare @datum date=getdate()
|
||||
create table #OraSorszam (TanitasioraId int, OraSorszam int)
|
||||
insert into #OraSorszam
|
||||
EXEC [sp_GetOraSorszamByOsztaly]
|
||||
@osztalyCsoportId = @csoportId,
|
||||
@datum = @datum,
|
||||
@intezmenyId = @intezmenyId,
|
||||
@tanevId = @tanevId
|
||||
|
||||
declare @mulasztas table (Csoport nvarchar(1), Tanulo int, Oraszam int)
|
||||
insert into @mulasztas
|
||||
select 'x' Csoport, tm.c_oratanuloiid Tanulo, oes.OraSorszam AS OraSzam from T_TANULOMULASZTAS_OSSZES tm
|
||||
inner join T_TANITASIORA_OSSZES tao on tm.c_tanitasiorakid=tao.id and tao.c_tanevid=@tanevid
|
||||
LEFT JOIN #OraSorszam oes on oes.TanitasioraId=tao.id
|
||||
where
|
||||
tao.c_osztalycsoportid=@csoportId
|
||||
AND tm.torolt='F'
|
||||
AND tm.c_tanevid=@tanevid
|
||||
AND tm.c_intezmenyid=@intezmenyid
|
||||
AND (@iskolaErdekuSzamit = 1 OR (C_IGAZOLASTIPUSA <> 1533 OR C_IGAZOLASTIPUSA IS NULL))
|
||||
|
||||
select f.c_nyomtatasinev Tanulo, tanulo.RovidNev Osztaly, m.[1], m.[2], m.[3], m.[4], m.[5], m.[6], m.[7], m.[8], m.[9], m.[10],
|
||||
m.[11], m.[12], m.[13], m.[14], m.[15], m.[16], m.[17], m.[18],m.[19],m.[20],
|
||||
m.[21], m.[22], m.[23], m.[24], m.[25], m.[26], m.[27], m.[28],m.[29],m.[30],
|
||||
m.[31], m.[32], m.[33], m.[34], m.[35], m.[36], m.[37], m.[38],m.[39],m.[40],
|
||||
m.[41], m.[42], m.[43], m.[44], m.[45], m.[46], m.[47], m.[48],m.[49],m.[50],
|
||||
osszesM.Osszes
|
||||
from @tanulo tanulo
|
||||
left join (select * from @mulasztas mulasztas pivot (max(Csoport) for Oraszam in ([1], [2], [3], [4], [5], [6], [7], [8], [9], [10],
|
||||
[11], [12], [13], [14], [15], [16], [17], [18],[19],[20],
|
||||
[21], [22], [23], [24], [25], [26], [27], [28],[29],[30],
|
||||
[31], [32], [33], [34], [35], [36], [37], [38],[39],[40],
|
||||
[41], [42], [43], [44], [45], [46], [47], [48],[49],[50])) pv)m on m.Tanulo=tanulo.Tanulo
|
||||
inner join T_FELHASZNALO_OSSZES f on f.id=tanulo.Tanulo
|
||||
left join (select Tanulo, count(Csoport) as Osszes from @mulasztas m group by Tanulo) osszesM on osszesM.Tanulo=tanulo.Tanulo
|
||||
order by f.c_nyomtatasinev
|
||||
|
||||
--napló
|
||||
declare @letszam int=(select count(tcs.c_tanuloid) from T_TANULOCSOPORT_OSSZES tcs where tcs.c_osztalycsoportid=@csoportId and tcs.Torolt='F')
|
||||
|
||||
select convert(nvarchar(max),datepart(year,tao.c_orakezdete))+'. '+convert(nvarchar(max),datepart(month,tao.c_orakezdete))+'. '+convert(nvarchar(max),datepart(day,tao.c_orakezdete))+'.' as Datum,
|
||||
tao.c_tema as Tema, @letszam-hianyzo.Hianyzok as Letszam, f.c_nyomtatasinev as Pedagogus from T_TANITASIORA_OSSZES tao
|
||||
inner join T_FOGLALKOZAS_OSSZES fog on fog.id=tao.c_foglalkozasid
|
||||
inner join T_FOGLALKOZASOK_TANAROK_OSSZES ft on ft.c_foglalkozasokid=fog.id
|
||||
left join (select tm.c_tanitasiorakid as Tanitasiora, count(tm.c_oratanuloiid) Hianyzok from T_TANULOMULASZTAS_OSSZES tm where tm.Torolt='F' group by tm.c_tanitasiorakid ) hianyzo on hianyzo.Tanitasiora=tao.id
|
||||
inner join T_FELHASZNALO_OSSZES f on f.id=iif(tao.c_helyettesitotanarid is not null,tao.c_helyettesitotanarid, ft.c_tanarokid)
|
||||
where tao.c_osztalycsoportid=@csoportId and tao.torolt='F' and tao.c_tanevid=@tanevid and tao.c_intezmenyid=@intezmenyid
|
||||
order by tao.c_orakezdete
|
||||
|
||||
--hiányzások
|
||||
declare @hianyzas table (Tanulo int, Osztaly nvarchar(max), Honap int, IgazoltE nvarchar(1))
|
||||
insert into @hianyzas
|
||||
select Tanulo, RovidNev, datepart(month,tao.c_datum) as Honap, tm.c_igazolt as IgazoltE from @tanulo tanulo
|
||||
left join T_TANULOMULASZTAS_OSSZES tm on tm.c_oratanuloiid=tanulo.Tanulo and tm.torolt='F' and tm.c_tanevid=@tanevid
|
||||
left join T_TANITASIORA_OSSZES tao on tao.id=tm.c_tanitasiorakid and tao.c_tanevid=@tanevid
|
||||
where
|
||||
tao.c_osztalycsoportid=@csoportId
|
||||
AND tao.torolt='F'
|
||||
AND (@iskolaErdekuSzamit = 1 OR (C_IGAZOLASTIPUSA <> 1533 OR C_IGAZOLASTIPUSA IS NULL))
|
||||
|
||||
select f.c_nyomtatasinev as Tanulo, tanulo.RovidNev Osztaly,
|
||||
--igazolt
|
||||
iif(i.[1]=0,null, i.[1]) as [1], iif(i.[2]=0,null, i.[2]) as [2], iif(i.[3]=0,null, i.[3]) as [3], iif(i.[4]=0,null, i.[4]) as [4], iif(i.[5]=0,null, i.[5]) as [5],iif(i.[6]=0,null, i.[6]) as [6],
|
||||
iif(i.[7]=0,null, i.[7]) as [7], iif(i.[8]=0,null, i.[8]) as [8], iif(i.[9]=0,null, i.[9]) as [9], iif(i.[10]=0,null, i.[10]) as [10], iif(i.[11]=0,null, i.[11]) as [11], iif(i.[12]=0,null, i.[12]) as [12],
|
||||
--igazolatlan
|
||||
iif(ni.[1]=0,null, ni.[1]) as n1, iif(ni.[2]=0,null, ni.[2]) as n2, iif(ni.[3]=0,null, ni.[3]) as n3, iif(ni.[4]=0,null, ni.[4]) as n4, iif(ni.[5]=0,null, ni.[5]) as n5,iif(ni.[6]=0,null, ni.[6]) as n6,
|
||||
iif(ni.[7]=0,null, ni.[7]) as n7, iif(ni.[8]=0,null, ni.[8]) as n8, iif(ni.[9]=0,null, ni.[9]) as n9, iif(ni.[10]=0,null, ni.[10]) as n10, iif(ni.[11]=0,null, ni.[11]) as n11, iif(ni.[12]=0,null, ni.[12]) as n12,
|
||||
igazolt.Igazolt, igazolatlan.Igazolatlan
|
||||
from @tanulo tanulo
|
||||
left join (select pv.* from @hianyzas hianyzas pivot (count(Honap) for Honap in ([1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]))pv where pv.IgazoltE='T')i on tanulo.Tanulo=i.Tanulo
|
||||
left join (select pv.* from @hianyzas hianyzas pivot (count(Honap) for Honap in ([1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]))pv where pv.IgazoltE='F')ni on tanulo.Tanulo=ni.Tanulo
|
||||
left join (select hianyzas.Tanulo Tanulo, count(IgazoltE) as Igazolt from @hianyzas hianyzas where hianyzas.IgazoltE='T' group by hianyzas.Tanulo) igazolt on igazolt.Tanulo=tanulo.Tanulo
|
||||
left join (select hianyzas.Tanulo Tanulo, count(IgazoltE) as Igazolatlan from @hianyzas hianyzas where hianyzas.IgazoltE='F' group by hianyzas.Tanulo) igazolatlan on igazolatlan.Tanulo=tanulo.Tanulo
|
||||
inner join T_FELHASZNALO_OSSZES f on f.id=tanulo.Tanulo
|
||||
|
||||
--Mulasztások összesen
|
||||
declare @hianyzasOssz table (Osztaly int, Honap int, IgazoltE nvarchar(1))
|
||||
insert into @hianyzasOssz
|
||||
select @csoportId, datepart(month,tao.c_datum) as Honap, tm.c_igazolt as IgazoltE from @tanulo tanulo
|
||||
left join T_TANULOMULASZTAS_OSSZES tm on tm.c_oratanuloiid=tanulo.Tanulo and tm.torolt='F' and tm.c_tanevid=@tanevid
|
||||
left join T_TANITASIORA_OSSZES tao on tao.id=tm.c_tanitasiorakid and tao.c_tanevid=@tanevid
|
||||
where
|
||||
tao.c_osztalycsoportid=@csoportId
|
||||
and tao.torolt='F'
|
||||
AND (@iskolaErdekuSzamit = 1 OR (C_IGAZOLASTIPUSA <> 1533 OR C_IGAZOLASTIPUSA IS NULL))
|
||||
|
||||
declare @igazoltH table (Csoport int, [1] int, [2] int, [3] int, [4] int, [5] int, [6] int, [7] int, [8] int, [9] int, [10] int,
|
||||
[11] int, [12] int)
|
||||
insert into @igazoltH
|
||||
select @csoportId, iif(i.[1]=0,null, i.[1]) as [1], iif(i.[2]=0,null, i.[2]) as [2], iif(i.[3]=0,null, i.[3]) as [3], iif(i.[4]=0,null, i.[4]) as [4], iif(i.[5]=0,null, i.[5]) as [5],iif(i.[6]=0,null, i.[6]) as [6],
|
||||
iif(i.[7]=0,null, i.[7]) as [7], iif(i.[8]=0,null, i.[8]) as [8], iif(i.[9]=0,null, i.[9]) as [9], iif(i.[10]=0,null, i.[10]) as [10], iif(i.[11]=0,null, i.[11]) as [11], iif(i.[12]=0,null, i.[12]) as [12]
|
||||
from @hianyzasOssz ho pivot (count(Honap) for Honap in ([1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]))i where i.IgazoltE='T'
|
||||
|
||||
--Mulasztott órák összesen
|
||||
declare @igazolatlanH table (Csoport int, [1] int, [2] int, [3] int, [4] int, [5] int, [6] int, [7] int, [8] int, [9] int, [10] int,
|
||||
[11] int, [12] int)
|
||||
insert into @igazolatlanH
|
||||
select @csoportId, iif(ni.[1]=0,null, ni.[1]) as n1, iif(ni.[2]=0,null, ni.[2]) as n2, iif(ni.[3]=0,null, ni.[3]) as n3, iif(ni.[4]=0,null, ni.[4]) as n4, iif(ni.[5]=0,null, ni.[5]) as n5,iif(ni.[6]=0,null, ni.[6]) as n6,
|
||||
iif(ni.[7]=0,null, ni.[7]) as n7, iif(ni.[8]=0,null, ni.[8]) as n8, iif(ni.[9]=0,null, ni.[9]) as n9, iif(ni.[10]=0,null, ni.[10]) as n10, iif(ni.[11]=0,null, ni.[11]) as n11, iif(ni.[12]=0,null, ni.[12]) as n12
|
||||
from @hianyzasOssz ho pivot (count(Honap) for Honap in ([1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]))ni where ni.IgazoltE='F'
|
||||
|
||||
select iif(i.[1]=0,null, i.[1]) as [1], iif(i.[2]=0,null, i.[2]) as [2], iif(i.[3]=0,null, i.[3]) as [3], iif(i.[4]=0,null, i.[4]) as [4], iif(i.[5]=0,null, i.[5]) as [5],iif(i.[6]=0,null, i.[6]) as [6],
|
||||
iif(i.[7]=0,null, i.[7]) as [7], iif(i.[8]=0,null, i.[8]) as [8], iif(i.[9]=0,null, i.[9]) as [9], iif(i.[10]=0,null, i.[10]) as [10], iif(i.[11]=0,null, i.[11]) as [11], iif(i.[12]=0,null, i.[12]) as [12],
|
||||
iif(ni.[1]=0,null, ni.[1]) as n1, iif(ni.[2]=0,null, ni.[2]) as n2, iif(ni.[3]=0,null, ni.[3]) as n3, iif(ni.[4]=0,null, ni.[4]) as n4, iif(ni.[5]=0,null, ni.[5]) as n5,iif(ni.[6]=0,null, ni.[6]) as n6,
|
||||
iif(ni.[7]=0,null, ni.[7]) as n7, iif(ni.[8]=0,null, ni.[8]) as n8, iif(ni.[9]=0,null, ni.[9]) as n9, iif(ni.[10]=0,null, ni.[10]) as n10, iif(ni.[11]=0,null, ni.[11]) as n11, iif(ni.[12]=0,null, ni.[12]) as n12
|
||||
from @igazolth i
|
||||
left join @igazolatlanH ni on i.Csoport=ni.csoport
|
||||
|
||||
--Mulasztó tanulók szama
|
||||
declare @Igazolt table (Csoport Int, Osszes int)
|
||||
insert into @Igazolt
|
||||
select @csoportId as Id, count(Tanulo) as IgazoltOsszes from (select distinct tanulo from @hianyzas where IgazoltE='T')m
|
||||
|
||||
select i.Osszes IgazoltOsszes, ni.Osszes IgazolatlanOsszes from @Igazolt i
|
||||
left join (select @csoportId as Id, count(Tanulo) as Osszes from (select distinct tanulo from @hianyzas where IgazoltE='F')m) ni on ni.Id=i.Csoport
|
||||
|
||||
--Mulasztott órák összesen-összesen
|
||||
declare @IgazoltOsszesOsszes table (Csoport Int, Osszes int)
|
||||
insert into @IgazoltOsszesOsszes
|
||||
select @csoportId, count(IgazoltE) from @hianyzasOssz where IgazoltE='T'
|
||||
|
||||
select ioo.Osszes IgazoltOsszesOsszes, nioo.Osszes as IgazolatlanOsszesOsszes from @IgazoltOsszesOsszes ioo
|
||||
left join (select @csoportId as Id, count(IgazoltE) Osszes from @hianyzasOssz where IgazoltE='F') nioo on nioo.Id=ioo.Csoport
|
||||
END
|
||||
|
||||
GO
|
@@ -0,0 +1,200 @@
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
|
||||
IF OBJECT_ID('[dbo].[sp_GetTanoranKivuliNaplo]') IS NOT NULL
|
||||
BEGIN
|
||||
DROP PROCEDURE [dbo].[sp_GetTanoranKivuliNaplo]
|
||||
END
|
||||
GO
|
||||
|
||||
|
||||
CREATE PROCEDURE [dbo].[sp_GetTanoranKivuliNaplo]
|
||||
@tanevId INT,
|
||||
@intezmenyId INT,
|
||||
@csoportId INT,
|
||||
@iskolaErdekuSzamit BIT
|
||||
|
||||
AS
|
||||
BEGIN
|
||||
SET NOCOUNT ON;
|
||||
|
||||
--Fejlecoldal (Fejléc)
|
||||
select ia.c_nev as IntezmenyNev, convert(nvarchar(5), ia.c_iranyitoszam)+', '+ia.c_varos+', '+ia.c_cime as IntezmenyCim, ia.c_omkod as OMKOD, ia.c_igazgatoneve as IntezmenyVezeto, ocs.c_nev Csoport,
|
||||
isnull(f.c_nyomtatasinev,'-') as CsoportVezeto, isnull(cs.c_csoportnaploleiras,'-') as CsoportNaploLeiras, FORMAT(cs.c_csoportnaplomegnyitasa, 'yyyy. MMMM dd.', 'hu-hu') as Megnyitas,
|
||||
isnull(FORMAT(cs.c_csoportnaplozarasa, 'yyyy. MMMM dd.', 'hu-hu'),'-') as Lezaras, t.c_nev as Tanev, cs.c_csoportnaploleiras as Megjegyzes from T_INTEZMENY_OSSZES i
|
||||
inner join T_INTEZMENYADATOK_OSSZES ia on ia.c_intezmenyid=i.id
|
||||
inner join T_OSZTALYCSOPORT_OSSZES ocs on ocs.c_intezmenyid=i.id
|
||||
inner join T_CSOPORT_OSSZES cs on cs.id=ocs.id
|
||||
left join T_FELHASZNALO_OSSZES f on f.id=cs.c_csoportvezetoid
|
||||
inner join T_TANEV_OSSZES t on t.id=ia.c_tanevid
|
||||
where i.id=@intezmenyid and ia.c_tanevid=@tanevid and ocs.id=@csoportId
|
||||
|
||||
--Osztaly (Csoport tanulóinak osztályai)
|
||||
select Osztaly.Osztaly Osztaly, count(c_tanuloid) Tanulo from t_tanulocsoport tcs
|
||||
inner join (select tcs.c_tanuloid Tanulo, ocs.c_nev as Osztaly, tcs.c_kilepesdatum Kilepes from T_TANULOCSOPORT_OSSZES tcs
|
||||
inner join T_OSZTALY_OSSZES o on o.id=tcs.c_osztalycsoportid and o.torolt='F'
|
||||
inner join T_OSZTALYCSOPORT_OSSZES ocs on o.id=ocs.id
|
||||
where tcs.TOROLT='F') osztaly on osztaly.Tanulo=tcs.c_tanuloid
|
||||
where tcs.c_osztalycsoportid=@csoportId and tcs.TOROLT='F' and tcs.c_kilepesdatum is null
|
||||
group by osztaly.Osztaly
|
||||
|
||||
--Mulasztasok
|
||||
declare @datum date=getdate()
|
||||
create table #OraSorszam (TanitasioraId int, OraSorszam int)
|
||||
insert into #OraSorszam
|
||||
EXEC [sp_GetOraSorszamByOsztaly]
|
||||
@osztalyCsoportId = @csoportId,
|
||||
@datum = @datum,
|
||||
@intezmenyId = @intezmenyId,
|
||||
@tanevId = @tanevId
|
||||
|
||||
DECLARE @tanulo TABLE (Tanulo int, Osztaly nvarchar(max))
|
||||
DECLARE @FelevVege date=(select top 1 c_datum from T_TANEVRENDJE_OSSZES te where te.c_naptipusa=1400 and te.c_intezmenyid=@intezmenyid and te.c_tanevid=@tanevid and te.torolt='F')
|
||||
|
||||
insert into @tanulo
|
||||
select f.id as Tanulo, Osztaly.Osztaly Osztaly from T_TANULOCSOPORT_OSSZES tcs
|
||||
inner join (select tcs.c_tanuloid Tanulo, ocs.c_nev Osztaly from T_TANULOCSOPORT_OSSZES tcs
|
||||
inner join T_OSZTALY_OSSZES o on o.id=tcs.c_osztalycsoportid and o.torolt='F'
|
||||
inner join T_OSZTALYCSOPORT_OSSZES ocs on ocs.id=tcs.c_osztalycsoportid --and ocs.c_intezmenyid=@intezmenyid and ocs.c_tanevid=@tanevid
|
||||
where tcs.c_kilepesdatum is null and tcs.c_tanevid=@tanevid) Osztaly on Osztaly.Tanulo=tcs.c_tanuloid
|
||||
inner join t_felhasznalo f on f.id=tcs.c_tanuloid
|
||||
where tcs.c_osztalycsoportid=@csoportId and tcs.TOROLT='F'
|
||||
|
||||
declare @mulasztas table (Csoport nvarchar(1), Tanulo int, Oraszam int, Felev int)
|
||||
insert into @mulasztas
|
||||
select 'x' Csoport, tm.c_oratanuloiid Tanulo, oes.OraSorszam OraSzam, iif(tao.c_datum<@FelevVege,1,2) from T_TANULOMULASZTAS_OSSZES tm
|
||||
inner join T_TANITASIORA_OSSZES tao on tm.c_tanitasiorakid=tao.id
|
||||
left join #OraSorszam oes on oes.TanitasioraId=tao.id
|
||||
where
|
||||
tao.c_osztalycsoportid=@csoportId
|
||||
AND tao.torolt='F' and tm.torolt='F'
|
||||
AND tm.c_tanevid=@tanevid
|
||||
AND tm.c_intezmenyid=@intezmenyid
|
||||
AND (@iskolaErdekuSzamit = 1 OR (C_IGAZOLASTIPUSA <> 1533 OR C_IGAZOLASTIPUSA IS NULL))
|
||||
|
||||
select f.c_nyomtatasinev Tanulo, tanulo.Osztaly,
|
||||
m.[1], m.[2], m.[3], m.[4], m.[5], m.[6], m.[7], m.[8], m.[9], m.[10],
|
||||
m.[11], m.[12], m.[13], m.[14], m.[15], m.[16], m.[17], m.[18],m.[19],m.[20],
|
||||
m.[21], m.[22], m.[23], m.[24], m.[25], m.[26], m.[27], m.[28],m.[29],m.[30],
|
||||
m.[31], m.[32], m.[33], m.[34], m.[35], m.[36], m.[37], m.[38],m.[39],m.[40],
|
||||
m.[41], m.[42], m.[43], m.[44], m.[45], m.[46], m.[47], m.[48],m.[49],m.[50],
|
||||
osszesM.Osszes, /*1. félév*/
|
||||
m2.[1] m1, m2.[2] m2, m2.[3] m3, m2.[4] m4, m2.[5] m5, m2.[6] m6, m2.[7] m7, m2.[8] m8, m2.[9] m9, m2.[10] m10,
|
||||
m2.[11] m11, m2.[12] m12, m2.[13] m13, m2.[14] m14, m2.[15] m15, m2.[16] m16, m2.[17] m17, m2.[18] m18, m2.[19] m19, m2.[20] m20,
|
||||
m2.[21] m21, m2.[22] m22, m2.[23] m23, m2.[24] m24, m2.[25] m25, m2.[26] m26, m2.[27] m27, m2.[28] m28, m2.[29] m29, m2.[30] m30,
|
||||
m2.[31] m31, m2.[32] m32, m2.[33] m33, m2.[34] m34, m2.[35] m35, m2.[36] m36, m2.[37] m37, m2.[38] m38, m2.[39] m39, m2.[40] m40,
|
||||
m2.[41] m41, m2.[42] m42, m2.[43] m43, m2.[44] m44, m2.[45] m45, m2.[46] m46, m2.[47] m47, m2.[48] m48, m2.[49] m49, m2.[50] m50,
|
||||
osszesM2.Osszes OsszesM/*2. félév*/
|
||||
from @tanulo tanulo
|
||||
|
||||
/* 1. félév*/
|
||||
left join (select * from @mulasztas mulasztas pivot (max(Csoport) for Oraszam in ([1], [2], [3], [4], [5], [6], [7], [8], [9], [10],
|
||||
[11], [12], [13], [14], [15], [16], [17], [18],[19],[20],
|
||||
[21], [22], [23], [24], [25], [26], [27], [28],[29],[30],
|
||||
[31], [32], [33], [34], [35], [36], [37], [38],[39],[40],
|
||||
[41], [42], [43], [44], [45], [46], [47], [48],[49],[50])) pv where pv.Felev=1)m on m.Tanulo=tanulo.Tanulo
|
||||
|
||||
left join (select * from @mulasztas mulasztas pivot (max(Csoport) for Oraszam in ([1], [2], [3], [4], [5], [6], [7], [8], [9], [10],
|
||||
[11], [12], [13], [14], [15], [16], [17], [18],[19],[20],
|
||||
[21], [22], [23], [24], [25], [26], [27], [28],[29],[30],
|
||||
[31], [32], [33], [34], [35], [36], [37], [38],[39],[40],
|
||||
[41], [42], [43], [44], [45], [46], [47], [48],[49],[50])) pv where pv.Felev=2)m2 on m2.Tanulo=tanulo.Tanulo
|
||||
|
||||
inner join T_FELHASZNALO_OSSZES f on f.id=tanulo.Tanulo
|
||||
left join (select Tanulo, count(Csoport) as Osszes from @mulasztas m where Felev=1 group by Tanulo) osszesM on osszesM.Tanulo=tanulo.Tanulo
|
||||
left join (select Tanulo, count(Csoport) as Osszes from @mulasztas m where Felev=2 group by Tanulo) osszesM2 on osszesM2.Tanulo=tanulo.Tanulo
|
||||
order by f.c_nyomtatasinev
|
||||
|
||||
--Napló
|
||||
declare @letszam int=(select count(tcs.c_tanuloid) from T_TANULOCSOPORT_OSSZES tcs where tcs.c_osztalycsoportid=@csoportId and tcs.TOROLT='F' and tcs.c_kilepesdatum is null)
|
||||
|
||||
select convert(nvarchar(max),datepart(year,tao.c_orakezdete))+'. '+convert(nvarchar(max),datepart(month,tao.c_orakezdete))+'. '+convert(nvarchar(max),datepart(day,tao.c_orakezdete))+'.' as Datum,
|
||||
tao.c_tema as Tema, @letszam-isnull(hianyzo.Hianyzok,0) as Letszam, f.c_nyomtatasinev as Pedagogus from T_TANITASIORA_OSSZES tao
|
||||
inner join T_FOGLALKOZAS_OSSZES fog on fog.id=tao.c_foglalkozasid
|
||||
inner join T_FOGLALKOZASOK_TANAROK_OSSZES ft on ft.c_foglalkozasokid=fog.id
|
||||
left join (select tm.c_tanitasiorakid as Tanitasiora, count(tm.c_oratanuloiid) Hianyzok from T_TANULOMULASZTAS_OSSZES tm where tm.torolt='F' group by tm.c_tanitasiorakid ) hianyzo on hianyzo.Tanitasiora=tao.id
|
||||
inner join T_FELHASZNALO_OSSZES f on f.id=iif(tao.c_helyettesitotanarid is not null,tao.c_helyettesitotanarid, ft.c_tanarokid)
|
||||
where tao.c_osztalycsoportid=@csoportId and tao.torolt='F'
|
||||
order by tao.c_orakezdete
|
||||
|
||||
--Hiányzások
|
||||
declare @hianyzas table (Tanulo int, Osztaly nvarchar(max), Honap int, IgazoltE nvarchar(1))
|
||||
insert into @hianyzas
|
||||
select Tanulo, Osztaly, datepart(month,tao.c_datum) as Honap, tm.c_igazolt as IgazoltE from @tanulo tanulo
|
||||
left join T_TANULOMULASZTAS_OSSZES tm on tm.c_oratanuloiid=tanulo.Tanulo and tm.torolt='F' and tm.c_tanevid=@tanevid and tm.c_intezmenyid=@intezmenyid
|
||||
left join T_TANITASIORA_OSSZES tao on tao.id=tm.c_tanitasiorakid and tao.c_tanevid=@tanevid and tao.c_intezmenyid=@intezmenyid
|
||||
where
|
||||
tao.c_osztalycsoportid=@csoportId
|
||||
AND (@iskolaErdekuSzamit = 1 OR (C_IGAZOLASTIPUSA <> 1533 OR C_IGAZOLASTIPUSA IS NULL))
|
||||
and tao.torolt='F'
|
||||
|
||||
select f.c_nyomtatasinev as Tanulo, tanulo.Osztaly,
|
||||
--igazolt
|
||||
iif(i.[1]=0,null, i.[1]) as [1], iif(i.[2]=0,null, i.[2]) as [2], iif(i.[3]=0,null, i.[3]) as [3], iif(i.[4]=0,null, i.[4]) as [4], iif(i.[5]=0,null, i.[5]) as [5],iif(i.[6]=0,null, i.[6]) as [6],
|
||||
iif(i.[7]=0,null, i.[7]) as [7], iif(i.[8]=0,null, i.[8]) as [8], iif(i.[9]=0,null, i.[9]) as [9], iif(i.[10]=0,null, i.[10]) as [10], iif(i.[11]=0,null, i.[11]) as [11], iif(i.[12]=0,null, i.[12]) as [12],
|
||||
--igazolatlan
|
||||
iif(ni.[1]=0,null, ni.[1]) as n1, iif(ni.[2]=0,null, ni.[2]) as n2, iif(ni.[3]=0,null, ni.[3]) as n3, iif(ni.[4]=0,null, ni.[4]) as n4, iif(ni.[5]=0,null, ni.[5]) as n5,iif(ni.[6]=0,null, ni.[6]) as n6,
|
||||
iif(ni.[7]=0,null, ni.[7]) as n7, iif(ni.[8]=0,null, ni.[8]) as n8, iif(ni.[9]=0,null, ni.[9]) as n9, iif(ni.[10]=0,null, ni.[10]) as n10, iif(ni.[11]=0,null, ni.[11]) as n11, iif(ni.[12]=0,null, ni.[12]) as n12,
|
||||
igazolt.Igazolt, igazolatlan.Igazolatlan
|
||||
from @tanulo tanulo
|
||||
left join (select pv.* from @hianyzas hianyzas pivot (count(Honap) for Honap in ([1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]))pv where pv.IgazoltE='T')i on tanulo.Tanulo=i.Tanulo
|
||||
left join (select pv.* from @hianyzas hianyzas pivot (count(Honap) for Honap in ([1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]))pv where pv.IgazoltE='F')ni on tanulo.Tanulo=ni.Tanulo
|
||||
left join (select hianyzas.Tanulo Tanulo, count(IgazoltE) as Igazolt from @hianyzas hianyzas where hianyzas.IgazoltE='T' group by hianyzas.Tanulo) igazolt on igazolt.Tanulo=tanulo.Tanulo
|
||||
left join (select hianyzas.Tanulo Tanulo, count(IgazoltE) as Igazolatlan from @hianyzas hianyzas where hianyzas.IgazoltE='F' group by hianyzas.Tanulo) igazolatlan on igazolatlan.Tanulo=tanulo.Tanulo
|
||||
inner join t_felhasznalo f on f.id=tanulo.Tanulo
|
||||
|
||||
--Hiányzások (Összesítő)
|
||||
declare @hianyzasOssz table (Osztaly int, Honap int, IgazoltE nvarchar(1))
|
||||
insert into @hianyzasOssz
|
||||
select @csoportId, datepart(month,tao.c_datum) as Honap, tm.c_igazolt as IgazoltE from @tanulo tanulo
|
||||
left join T_TANULOMULASZTAS_OSSZES tm on tm.c_oratanuloiid=tanulo.Tanulo and tm.torolt='F' and tm.c_tanevid=@tanevid --and tm.c_intezmenyid=@intezmenyid
|
||||
left join T_TANITASIORA_OSSZES tao on tao.id=tm.c_tanitasiorakid and tao.c_tanevid=@tanevid --and tao.c_intezmenyid=@intezmenyid
|
||||
where
|
||||
tao.c_osztalycsoportid=@csoportId
|
||||
and tao.torolt='F'
|
||||
AND (@iskolaErdekuSzamit = 1 OR (C_IGAZOLASTIPUSA <> 1533 OR C_IGAZOLASTIPUSA IS NULL))
|
||||
|
||||
declare @igazoltH table (Csoport int, [1] int, [2] int, [3] int, [4] int, [5] int, [6] int, [7] int, [8] int, [9] int, [10] int,
|
||||
[11] int, [12] int)
|
||||
insert into @igazoltH
|
||||
select @csoportId, iif(i.[1]=0,null, i.[1]) as [1], iif(i.[2]=0,null, i.[2]) as [2], iif(i.[3]=0,null, i.[3]) as [3], iif(i.[4]=0,null, i.[4]) as [4], iif(i.[5]=0,null, i.[5]) as [5],iif(i.[6]=0,null, i.[6]) as [6],
|
||||
iif(i.[7]=0,null, i.[7]) as [7], iif(i.[8]=0,null, i.[8]) as [8], iif(i.[9]=0,null, i.[9]) as [9], iif(i.[10]=0,null, i.[10]) as [10], iif(i.[11]=0,null, i.[11]) as [11], iif(i.[12]=0,null, i.[12]) as [12]
|
||||
from @hianyzasOssz ho pivot (count(Honap) for Honap in ([1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]))i where i.IgazoltE='T'
|
||||
|
||||
declare @igazolatlanH table (Csoport int, [1] int, [2] int, [3] int, [4] int, [5] int, [6] int, [7] int, [8] int, [9] int, [10] int,
|
||||
[11] int, [12] int)
|
||||
insert into @igazolatlanH
|
||||
select @csoportId, iif(ni.[1]=0,null, ni.[1]) as n1, iif(ni.[2]=0,null, ni.[2]) as n2, iif(ni.[3]=0,null, ni.[3]) as n3, iif(ni.[4]=0,null, ni.[4]) as n4, iif(ni.[5]=0,null, ni.[5]) as n5,iif(ni.[6]=0,null, ni.[6]) as n6,
|
||||
iif(ni.[7]=0,null, ni.[7]) as n7, iif(ni.[8]=0,null, ni.[8]) as n8, iif(ni.[9]=0,null, ni.[9]) as n9, iif(ni.[10]=0,null, ni.[10]) as n10, iif(ni.[11]=0,null, ni.[11]) as n11, iif(ni.[12]=0,null, ni.[12]) as n12
|
||||
from @hianyzasOssz ho pivot (count(Honap) for Honap in ([1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]))ni where ni.IgazoltE='F'
|
||||
|
||||
--Hiányzás (Mulasztott órák összesen)
|
||||
select iif(i.[1]=0,null, i.[1]) as [1], iif(i.[2]=0,null, i.[2]) as [2], iif(i.[3]=0,null, i.[3]) as [3], iif(i.[4]=0,null, i.[4]) as [4], iif(i.[5]=0,null, i.[5]) as [5],iif(i.[6]=0,null, i.[6]) as [6],
|
||||
iif(i.[7]=0,null, i.[7]) as [7], iif(i.[8]=0,null, i.[8]) as [8], iif(i.[9]=0,null, i.[9]) as [9], iif(i.[10]=0,null, i.[10]) as [10], iif(i.[11]=0,null, i.[11]) as [11], iif(i.[12]=0,null, i.[12]) as [12],
|
||||
iif(ni.[1]=0,null, ni.[1]) as n1, iif(ni.[2]=0,null, ni.[2]) as n2, iif(ni.[3]=0,null, ni.[3]) as n3, iif(ni.[4]=0,null, ni.[4]) as n4, iif(ni.[5]=0,null, ni.[5]) as n5,iif(ni.[6]=0,null, ni.[6]) as n6,
|
||||
iif(ni.[7]=0,null, ni.[7]) as n7, iif(ni.[8]=0,null, ni.[8]) as n8, iif(ni.[9]=0,null, ni.[9]) as n9, iif(ni.[10]=0,null, ni.[10]) as n10, iif(ni.[11]=0,null, ni.[11]) as n11, iif(ni.[12]=0,null, ni.[12]) as n12
|
||||
from @igazolth i
|
||||
left join @igazolatlanH ni on ni.Csoport=i.csoport
|
||||
|
||||
--Hiányzás (Mulasztó tanulók száma)
|
||||
declare @Igazolt table (Csoport Int, Osszes int)
|
||||
insert into @Igazolt
|
||||
select @csoportId as Id, count(Tanulo) as IgazoltOsszes from (select distinct tanulo from @hianyzas where IgazoltE='T')m
|
||||
|
||||
select i.Osszes IgazoltOsszes, ni.Osszes IgazolatlanOsszes from @Igazolt i
|
||||
left join (select @csoportId as Id, count(Tanulo) as Osszes from (select distinct tanulo from @hianyzas where IgazoltE='F')m) ni on ni.Id=i.Csoport
|
||||
|
||||
--Hiányzás (Mulasztott órák Összesen-Összesen)
|
||||
declare @IgazoltOsszesOsszes table (Csoport Int, Osszes int)
|
||||
insert into @IgazoltOsszesOsszes
|
||||
select @csoportId, count(IgazoltE) from @hianyzasOssz where IgazoltE='T'
|
||||
|
||||
select ioo.Osszes IgazoltOsszesOsszes, nioo.Osszes as IgazolatlanOsszesOsszes from @IgazoltOsszesOsszes ioo
|
||||
left join (select @csoportId as Id, count(IgazoltE) Osszes from @hianyzasOssz where IgazoltE='F') nioo on nioo.Id=ioo.Csoport
|
||||
|
||||
END
|
||||
|
||||
GO
|
@@ -0,0 +1,63 @@
|
||||
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
|
||||
IF OBJECT_ID('[dbo].[sp_GetTanulokFeljegyzesekReszletezese]') IS NOT NULL
|
||||
BEGIN
|
||||
DROP PROCEDURE [dbo].[sp_GetTanulokFeljegyzesekReszletezese]
|
||||
END
|
||||
GO
|
||||
-- =============================================
|
||||
-- Author: Dőrr Tamás
|
||||
-- Create date: 2015.12.15.
|
||||
-- Description: sp_GetTanulokFeljegyzesekReszletezese
|
||||
-- =============================================
|
||||
CREATE PROCEDURE [dbo].[sp_GetTanulokFeljegyzesekReszletezese]
|
||||
@pOsztalyId INT,
|
||||
@pTanevId INT
|
||||
AS
|
||||
BEGIN
|
||||
SET NOCOUNT ON;
|
||||
|
||||
select
|
||||
Datum as KEZDET
|
||||
,d.C_NAME AS C_TIPUS
|
||||
,ft.ID AS TANULO_ID
|
||||
,ft.C_NYOMTATASINEV AS TANULO_NEV
|
||||
,FeljegyzoNeve AS FELJEGYZO_NEV
|
||||
,Tartalom AS TARTALOM
|
||||
,Megjegyzes AS MEGJEGYZES
|
||||
,i.C_IGAZGATONEVE AS INT_IGAZGATO_NEV
|
||||
,i.C_NEV AS INT_NEV
|
||||
,i.C_OMKOD AS INT_OMKOD
|
||||
,i.C_IRANYITOSZAM AS INT_IRSZAM
|
||||
,i.C_VAROS AS INT_VAROS
|
||||
,i.C_CIME AS INT_CIM
|
||||
,i.C_IRANYITOSZAM + ' ' + i.C_VAROS + ' ' + i.C_CIME AS INT_TELJES_CIM
|
||||
,(SELECT C_NEV FROM T_OSZTALYCSOPORT_OSSZES WHERE ID = @pOsztalyId) as OSZTALYCSOPORT_NEV
|
||||
,(SELECT C_NYOMTATASINEV FROM T_OSZTALY_OSSZES osztaly
|
||||
INNER JOIN T_FELHASZNALO_OSSZES osztalyfonok on osztalyfonok.ID = osztaly.C_OSZTALYFONOKID
|
||||
WHERE osztaly.ID = @pOsztalyId
|
||||
) AS OSZTFO_NEV
|
||||
,ft.C_NYOMTATASINEV + ' ' + CAST(ft.ID AS NVARCHAR) AS GROUPPARAMETER
|
||||
FROM fnGetDokumentumTanulokFeljegyzesei(@pTanevId, @pOsztalyId) esemenyek
|
||||
LEFT JOIN T_FELHASZNALO_OSSZES ft ON ft.ID = esemenyek.Tanuloid
|
||||
LEFT JOIN T_INTEZMENYADATOK_OSSZES i ON i.C_TANEVID = ft.C_TANEVID
|
||||
INNER JOIN T_DICTIONARYITEMBASE_OSSZES d ON d.id = Tipusa AND d.C_TANEVID = ft.C_TANEVID AND d.C_INTEZMENYID = ft.C_INTEZMENYID
|
||||
WHERE
|
||||
Tipusa != 1534
|
||||
ORDER BY ft.C_NYOMTATASINEV
|
||||
|
||||
SELECT
|
||||
C_OSZTALYFONOKID PartnerID
|
||||
FROM T_OSZTALY_OSSZES
|
||||
WHERE
|
||||
T_OSZTALY_OSSZES.ID = @pOsztalyId
|
||||
AND T_OSZTALY_OSSZES.TOROLT='F'
|
||||
AND T_OSZTALY_OSSZES.C_ALTANEVID = @pTanevId
|
||||
END
|
||||
|
||||
GO
|
@@ -0,0 +1,202 @@
|
||||
GO
|
||||
|
||||
SET ANSI_NULLS ON
|
||||
GO
|
||||
SET QUOTED_IDENTIFIER ON
|
||||
GO
|
||||
|
||||
IF OBJECT_ID('sp_GetTorzslap') IS NOT NULL BEGIN
|
||||
DROP PROCEDURE [sp_GetTorzslap]
|
||||
END
|
||||
GO
|
||||
|
||||
CREATE PROCEDURE [sp_GetTorzslap]
|
||||
@osztalyId INT,
|
||||
@tanevId INT,
|
||||
@ertekelesTipus INT,
|
||||
@kesesTipus INT,
|
||||
@elmeletiOraPercben INT = 45,
|
||||
@gyakorlatiOraPercben INT = 60,
|
||||
@iskolaErdekuSzamit BIT
|
||||
AS
|
||||
BEGIN
|
||||
SET NOCOUNT ON;
|
||||
|
||||
--Intézmény, tanév
|
||||
SELECT T_INTEZMENYADATOK_OSSZES.C_NEV IntezmenyNeve,
|
||||
T_INTEZMENYADATOK_OSSZES.C_IRANYITOSZAM IntezmenyIranyitoszam,
|
||||
T_INTEZMENYADATOK_OSSZES.C_VAROS IntezmenyVaros,
|
||||
T_INTEZMENYADATOK_OSSZES.C_CIME IntezmenyCime,
|
||||
T_INTEZMENYADATOK_OSSZES.C_TELEFONSZAM TELEFON,
|
||||
T_INTEZMENYADATOK_OSSZES.C_EMAILCIM EMAILCIM,
|
||||
T_INTEZMENYADATOK_OSSZES.C_OMKOD IntezmenyOMKod,
|
||||
T_TANEV_OSSZES.C_NEV TANEV
|
||||
FROM T_INTEZMENYADATOK_OSSZES
|
||||
INNER JOIN T_TANEV_OSSZES ON T_TANEV_OSSZES.ID = T_INTEZMENYADATOK_OSSZES.C_TANEVID and T_TANEV_OSSZES.TOROLT = 'F'
|
||||
WHERE T_TANEV_OSSZES.ID = @tanevId
|
||||
|
||||
--Osztály, évfolyam
|
||||
SELECT
|
||||
T_OSZTALYCSOPORT_OSSZES.C_NEV,
|
||||
T_OSZTALYCSOPORT_OSSZES.C_EVFOLYAMTIPUSA
|
||||
FROM T_OSZTALYCSOPORT_OSSZES
|
||||
WHERE
|
||||
T_OSZTALYCSOPORT_OSSZES.ID = @osztalyId
|
||||
|
||||
--Osztályhoz tartozó tanulók
|
||||
DECLARE @Tanulok TABLE (TanuloId int)
|
||||
INSERT INTO @Tanulok
|
||||
SELECT TanuloId FROM fnGetDokumentumOsztalyokCsoportokTanuloi(@tanevId, @osztalyId, 'T')
|
||||
|
||||
--Tanuló adatok
|
||||
DECLARE @NaploSorszam TABLE (
|
||||
TanuloId INT
|
||||
,Sorszam INT
|
||||
)
|
||||
|
||||
INSERT INTO @NaploSorszam
|
||||
EXEC sp_GetDokumentumTanuloNaploSorszam
|
||||
@osztalyId = @osztalyId
|
||||
|
||||
SELECT
|
||||
felhasznalo.ID TanuloId,
|
||||
felhasznalo.Azonosito,
|
||||
felhasznalo.Nev,
|
||||
felhasznalo.SzuletesiDatum,
|
||||
felhasznalo.SzuletesiHely,
|
||||
felhasznalo.Allampolgarsag,
|
||||
felhasznalo.Anyjaneve,
|
||||
felhasznalo.SzuletesiOrszag,
|
||||
felhasznalo.TorzslapSzam,
|
||||
gondviselo.Nev GondviseloNeve,
|
||||
gondviselo.Rokonsag,
|
||||
naploSorszam.Sorszam NaploSorszam,
|
||||
Adatvaltozas.Feljegyzes Adatvaltozas
|
||||
FROM
|
||||
(
|
||||
SELECT
|
||||
T_FELHASZNALO_OSSZES.ID AS ID,
|
||||
T_FELHASZNALO_OSSZES.C_OKTATASIAZONOSITO Azonosito,
|
||||
T_FELHASZNALO_OSSZES.C_NYOMTATASINEV Nev,
|
||||
T_FELHASZNALO_OSSZES.C_SZULETESIDATUM SzuletesiDatum,
|
||||
T_FELHASZNALO_OSSZES.C_SZULETESIHELY SzuletesiHely,
|
||||
T_FELHASZNALO_OSSZES.C_SZULETESIORSZAG SzuletesiOrszag,
|
||||
T_FELHASZNALO_OSSZES.C_ALLAMPOLGARSAGA Allampolgarsag,
|
||||
T_FELHASZNALO_OSSZES.C_ANYJANEVE Anyjaneve,
|
||||
T_FELHASZNALO_OSSZES.C_NYILVANTARTASISZAM TorzslapSzam
|
||||
FROM T_FELHASZNALO_OSSZES
|
||||
INNER JOIN @Tanulok TANCSOPORT
|
||||
ON TANCSOPORT.TanuloId = T_FELHASZNALO_OSSZES.ID
|
||||
WHERE
|
||||
T_FELHASZNALO_OSSZES.C_TANEVID = @tanevId
|
||||
AND T_FELHASZNALO_OSSZES.TOROLT='F'
|
||||
) felhasznalo
|
||||
LEFT JOIN
|
||||
(SELECT
|
||||
T_GONDVISELO_OSSZES.C_NEV Gondviselo,
|
||||
T_GONDVISELO_OSSZES.C_ROKONSAGFOKA Rokonsag,
|
||||
T_GONDVISELO_OSSZES.C_TANULOID Id,
|
||||
T_GONDVISELO_OSSZES.C_NEV Nev
|
||||
FROM T_GONDVISELO_OSSZES
|
||||
WHERE T_GONDVISELO_OSSZES.TOROLT='F'
|
||||
) gondviselo on felhasznalo.ID = gondviselo.ID
|
||||
LEFT JOIN @NaploSorszam naploSorszam on naploSorszam.TanuloId = felhasznalo.ID
|
||||
LEFT JOIN (SELECT DISTINCT
|
||||
hatarozat.TanuloId
|
||||
,STUFF((SELECT ' | ' + CAST(Tartalom AS VARCHAR(max))
|
||||
FROM fnGetDokumentumTanulokFeljegyzesei(@tanevId, @osztalyId) bhatarozat
|
||||
WHERE
|
||||
bhatarozat.TanuloId=hatarozat.TanuloId
|
||||
AND Tipusa = 1545
|
||||
FOR XML PATH(''), TYPE)
|
||||
.value('.','NVARCHAR(MAX)'),1,2,' ') Feljegyzes
|
||||
FROM fnGetDokumentumTanulokFeljegyzesei(@tanevId, @osztalyId) hatarozat
|
||||
WHERE
|
||||
Tipusa = 1545 --Feljegyzések személyi adatok változásához:
|
||||
) Adatvaltozas on Adatvaltozas.TanuloId = felhasznalo.ID
|
||||
ORDER BY felhasznalo.Nev
|
||||
|
||||
--Határozat
|
||||
SELECT
|
||||
hatarozat.TanuloId TanuloId
|
||||
,Tartalom Bejegyzes
|
||||
FROM fnGetDokumentumTanulokFeljegyzesei(@tanevId, @osztalyId) hatarozat
|
||||
WHERE
|
||||
Tipusa = 1548 --évvégi
|
||||
|
||||
--Egyéb bejegyzések
|
||||
SELECT
|
||||
bejegyzes.TanuloId TanuloId
|
||||
,Tartalom Bejegyzes
|
||||
,Tipusa Tipus
|
||||
FROM fnGetDokumentumTanulokFeljegyzesei(@tanevId, @osztalyId) bejegyzes
|
||||
WHERE
|
||||
Tipusa IN (1546, 1553)
|
||||
ORDER BY bejegyzes.TanuloId
|
||||
|
||||
-- MULASZTÁSOK
|
||||
DECLARE @Mulasztasok TABLE (
|
||||
TanuloId INT
|
||||
,Igazolt INT
|
||||
,Igazolatlan INT
|
||||
,ElmeletIgazolt INT
|
||||
,ElmeletIgazolatlan INT
|
||||
,GyakorlatIgazolt INT
|
||||
,GyakorlatIgazolatlan INT
|
||||
,Osszes INT
|
||||
)
|
||||
|
||||
INSERT INTO @Mulasztasok
|
||||
EXEC sp_GetDokumentumMulasztasok
|
||||
@osztalyId = @osztalyId,
|
||||
@tanevId = @tanevId,
|
||||
@elmeletGyakorlat = 0,
|
||||
@kesesTipus = @kesesTipus,
|
||||
@elmeletiOraPercben = @elmeletiOraPercben,
|
||||
@gyakorlatiOraPercben = @gyakorlatiOraPercben,
|
||||
@ertekelesTipus = @ertekelesTipus,
|
||||
@iskolaErdekuSzamit = @iskolaErdekuSzamit
|
||||
|
||||
SELECT
|
||||
TanuloId
|
||||
,Igazolt
|
||||
,Igazolatlan
|
||||
,ElmeletIgazolt
|
||||
,ElmeletIgazolatlan
|
||||
,GyakorlatIgazolt
|
||||
,GyakorlatIgazolatlan
|
||||
,Osszes
|
||||
FROM @Mulasztasok
|
||||
|
||||
-- ÉRTÉKELÉSEK
|
||||
DECLARE @Ertekelesek TABLE (
|
||||
TanuloId INT
|
||||
,Targy NVARCHAR(MAX)
|
||||
,Ertekeles NVARCHAR(MAX)
|
||||
,Jegyzet NVARCHAR(MAX)
|
||||
,ErtekelesJegyzettel NVARCHAR(MAX)
|
||||
,SzovegesErtekeles NVARCHAR(MAX)
|
||||
,Oraszam INT
|
||||
,RENDEZ INT
|
||||
)
|
||||
|
||||
INSERT INTO @Ertekelesek
|
||||
EXEC sp_GetDokumentumErtekelesek
|
||||
@osztalyId = @osztalyId,
|
||||
@tanevId = @tanevId,
|
||||
@ertekelesTipus = @ertekelesTipus
|
||||
|
||||
SELECT
|
||||
TanuloId
|
||||
, Targy
|
||||
, Ertekeles
|
||||
, Jegyzet
|
||||
, ErtekelesJegyzettel
|
||||
,SzovegesErtekeles
|
||||
, Oraszam
|
||||
, RENDEZ
|
||||
FROM
|
||||
@Ertekelesek
|
||||
END
|
||||
|
||||
GO
|
Reference in New Issue
Block a user