다음 오류 메시지가 나타납니다.데이터 정렬 충돌을 해결할 수 없습니다.
동등 작업에서 "Latin1_General_CI_AI"와 "SQL_Latin1_General_CP1_CI_AS"간의 데이터 정렬 충돌을 해결할 수 없습니다.
아래 코드를 WHERE 절에 넣으면 나옵니다.
WHERE Region IN (SELECT Token FROM dbo.getParmsFromString(@Region))
이제 @Region에는 내 다중 선택 필드 인 SSRS의 모든 값이 포함되어 있습니다.
다음은 사용되는 기능 코드입니다.
CREATE FUNCTION [dbo].[getParmsFromString]
(@String VARCHAR(MAX))
RETURNS @Parms TABLE
(
Token VARCHAR(MAX)
)
AS
BEGIN
IF CHARINDEX(',', @String) != 0
BEGIN
;WITH cte0(Token, List) AS
(
SELECT SUBSTRING(@String, 1, CHARINDEX(',',@String,1) - 1)
,SUBSTRING(@String,CHARINDEX(',',@String,1) + 1, LEN(@String)) + ','
UNION ALL
SELECT SUBSTRING(List,1,ISNULL(CHARINDEX(',',List,1) - 1,1))
,SUBSTRING(List,CHARINDEX(',',List,1) + 1, LEN(List))
FROM cte0
WHERE LEN(cte0.List) > 0
)
INSERT INTO @Parms (Token)
SELECT Token
FROM cte0
OPTION (MAXRECURSION 0)
RETURN;
END
ELSE
INSERT INTO @Parms
SELECT @String
RETURN;
END