52 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Transact-SQL
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Transact-SQL
		
	
	
	
	
	
SET ANSI_NULLS ON
 | 
						|
GO
 | 
						|
SET QUOTED_IDENTIFIER ON
 | 
						|
GO
 | 
						|
 | 
						|
IF OBJECT_ID('[dbo].[sp_GetFelhasznaloOsztalyaiByFoglalkozas]') IS NOT NULL 
 | 
						|
BEGIN
 | 
						|
  DROP PROCEDURE [dbo].[sp_GetFelhasznaloOsztalyaiByFoglalkozas]
 | 
						|
END  
 | 
						|
GO
 | 
						|
 | 
						|
-- =============================================
 | 
						|
-- Description:	<Felhasználóhoz köthetõ osztályok foglalkozások alapján az értékelések szûréséhez>
 | 
						|
-- =============================================
 | 
						|
 | 
						|
CREATE PROCEDURE [dbo].[sp_GetFelhasznaloOsztalyaiByFoglalkozas]
 | 
						|
	@felhasznaloId INT,
 | 
						|
	@osztaly VARCHAR(32),
 | 
						|
	@csoport VARCHAR(32)
 | 
						|
AS
 | 
						|
BEGIN
 | 
						|
 | 
						|
	-- SET NOCOUNT ON added to prevent extra result sets from
 | 
						|
	-- interfering with SELECT statements.
 | 
						|
	SET NOCOUNT ON;
 | 
						|
	
 | 
						|
	SELECT DISTINCT
 | 
						|
		CASE WHEN osztalyCsoport.C_NEV NOT LIKE '%[^0-9]%' THEN CAST(LEFT(osztalyCsoport.C_NEV,9) AS INT) ELSE 2147483647 END NumberOrder,
 | 
						|
		CASE WHEN LEFT(osztalyCsoport.C_NEV, 1) BETWEEN '0' AND '9' AND osztalyCsoport.C_NEV LIKE '%[^0-9]%' THEN CAST(LEFT(SUBSTRING(osztalyCsoport.C_NEV, 1, PATINDEX('%[^0-9]%', osztalyCsoport.C_NEV) - 1),9) AS INT) ELSE 2147483647 END NumberAndTextOrder,
 | 
						|
		osztalyCsoport.ID 																									ID,
 | 
						|
		osztalyCsoport.C_NEV																								Nev,
 | 
						|
		CASE WHEN Osztaly IS  NOT NULL THEN @osztaly ELSE @csoport END														Tipus,
 | 
						|
		osztalyCsoport.C_EVFOLYAMTIPUSA																						Evfolyam
 | 
						|
	FROM 
 | 
						|
		T_FOGLALKOZAS foglalkozas
 | 
						|
		LEFT JOIN T_OSZTALYCSOPORT osztalyCsoport
 | 
						|
			ON osztalyCsoport.ID = foglalkozas.C_OSZTALYCSOPORTID
 | 
						|
		LEFT JOIN T_TANTARGY tantargy
 | 
						|
			ON tantargy.ID = foglalkozas.C_TANTARGYID
 | 
						|
		LEFT JOIN T_FELHASZNALO felhasznalo
 | 
						|
			ON felhasznalo.ID = foglalkozas.C_TANARID
 | 
						|
		LEFT JOIN (SELECT ID, 'T' AS Osztaly FROM T_OSZTALY_OSSZES) AS o
 | 
						|
			ON o.ID = osztalyCsoport.ID
 | 
						|
        LEFT JOIN (SELECT ID, C_TIPUSA FROM T_CSOPORT_OSSZES WHERE TOROLT = 'F') AS cs
 | 
						|
			ON cs.ID = osztalyCsoport.ID
 | 
						|
	WHERE 
 | 
						|
		foglalkozas.TOROLT = 'F' AND 
 | 
						|
		foglalkozas.C_TANARID = @felhasznaloId	
 | 
						|
	ORDER BY 
 | 
						|
		NumberOrder ASC, NumberAndTextOrder ASC, osztalyCsoport.C_NEV ASC	
 | 
						|
 | 
						|
END |