kreta/Kreta.DataAccess.Migrations/DBScripts/Database/dbo/Functions/fnGetOsztalyVegzosTanitasiNap.sql
2024-03-13 00:33:46 +01:00

27 lines
No EOL
1.1 KiB
Transact-SQL

IF OBJECT_ID('dbo.fnGetOsztalyVegzosTanitasiNap') IS NOT NULL BEGIN
DROP FUNCTION dbo.fnGetOsztalyVegzosTanitasiNap
END
GO
CREATE FUNCTION dbo.fnGetOsztalyVegzosTanitasiNap (@osztalyId INT, @intezmenyId INT, @tanevId INT)
RETURNS datetime
BEGIN
DECLARE @Global DATETIME = (SELECT MIN(C_DATUM) FROM T_TANEVRENDJE_OSSZES WHERE C_INTEZMENYID = @intezmenyId AND C_TANEVID = @tanevId
AND C_OSSZESCSOPORTRAVONATKOZIK = 'T' AND C_NAPTIPUSA IN (1402, 7600, 7601, 7602, 7603, 1395) AND TOROLT = 'F')
DECLARE @isVegzos CHAR(1) = (SELECT C_VEGZOSEVFOLYAM FROM T_OSZTALYCSOPORT_OSSZES WHERE ID = @osztalyId AND TOROLT = 'F' AND C_TANEVID = @tanevId)
DECLARE @result DATETIME
IF(@isVegzos = 'T')
BEGIN
SET @result =
(SELECT TOP(1) C_DATUM FROM (
SELECT C_DATUM FROM T_TANEVRENDJE_OSSZES tr
INNER JOIN T_OSZTALYCSOPORT_TANEVRENDJE otr ON tr.ID = otr.C_TANEVRENDJEID AND otr.C_OSZTALYCSOPORTID = @osztalyId
WHERE
C_NAPTIPUSA IN (1402, 7600, 7601, 7602, 7603) AND C_INTEZMENYID = @intezmenyId AND C_TANEVID = @tanevId AND tr.TOROLT = 'F'
) x ORDER BY C_DATUM)
END
RETURN ISNULL(@result, @Global)
END
GO