Привет, я пытаюсь выполнить запрос ниже. Где выход ProjectID равен 1,2,3. Я пытаюсь получить данные, используя ProjectID из другой таблицы.
DECLARE @ProjectID varchar(100)
DECLARE @ImpactIntakeID varchar(100)
set @ProjectID =
(SELECT STUFF ((SELECT ',' + CAST(Proj_ID AS VARCHAR) FROM PROJECT
WHERE YEAR(Enter_Dt) < (YEAR(GETDATE-()-7)) FOR XML PATH('')), 1, 1, '')
AS Enter_Date)
print @ProjectID
set @ImpactIntakeID =
(SELECT STUFF ((SELECT ',' + CAST([IMPCT_INTAKE_ID] AS VARCHAR) FROM [IMPCT_INTAKE_REQ]
WHERE [CNSDR_PROJ_ID] in (@ProjectID) FOR XML PATH('')), 1, 1, '')
AS ImpactIntakeID)
print @ImpactIntakeID
Я получаю ошибку преобразования. Ошибка преобразования при преобразовании значения varchar '1,2,3' в тип данных int. Я не уверен, где мне не хватает преобразования. Я также пробовал ниже ..
set @ImpactIntakeID =
(SELECT STUFF ((SELECT ',' + CAST([IMPCT_INTAKE_ID] AS VARCHAR) FROM [IMPCT_INTAKE_REQ]
WHERE [CNSDR_PROJ_ID] in (''+@ProjectID+'') FOR XML PATH('')), 1, 1, '')
AS ImpactIntakeID)
а также
set @ImpactIntakeID =
(SELECT STUFF ((SELECT ',' + CAST([IMPCT_INTAKE_ID] AS VARCHAR) FROM [IMPCT_INTAKE_REQ]
WHERE CAST([CNSDR_PROJ_ID] AS VARCHAR) in (@ProjectID) FOR XML PATH('')), 1, 1, '')
AS ImpactIntakeID)
Может ли кто-нибудь помочь, где я пропускаю преобразование...