Danke für Eure Anregungen... Ich hab bei meiner Internet Suche aber auch noch eine atraktive Lösung gefunden die auch Funktioniert...
Die fnSplit Funktion habe ich im Internet gefunden, über die kann ich die Werte auf Teile damit ich Sie wieder in einer IN Klausel verwenden kann...
Anbei die fnSplit Funktion und meine Stored Procedure, funktioniert wunderbar
SQL-Code:
/* Step 1 --> Create Split Function for WHERE IN Clause */
USE [inventory_test]
GO
CREATE FUNCTION fnSplit(@text nvarchar(max), @delimiter char(1) = ' ')
RETURNS @Strings TABLE
(
position int IDENTITY PRIMARY KEY,
value nvarchar(max)
)
AS
BEGIN
DECLARE @index int
SET @index = -1
WHILE (LEN(@text) > 0)
BEGIN
SET @index = CHARINDEX(@delimiter , @text)
IF (@index = 0) AND (LEN(@text) > 0)
BEGIN
INSERT INTO @Strings VALUES (@text)
BREAK
END
IF (@index > 1)
BEGIN
INSERT INTO @Strings VALUES (LEFT(@text, @index - 1))
SET @text = RIGHT(@text, (LEN(@text) - @index))
END
ELSE
SET @text = RIGHT(@text, (LEN(@text) - @index))
END
RETURN
END
/* Step 2 --> Create Procedure with WHERE IN Clause */
USE [inventory_test]
GO
CREATE PROCEDURE prGetCountryTable @Country varchar(255)
AS
Select * From [inventory_test].[dbo].[inventory_test.country]
Where COUNTRY In (SELECT value FROM [inventory_test].[dbo].[fnSplit](@Country, ';'))
GO
/* Step 3 --> Execute Procedure */
EXEC [inventory_test].[dbo].[prGetCountryTable] @Country = 'Austria;Australia'