Службы Reporting Services - запрос с несколькими значениями параметров, не дающий результатов

Используя SSRS (SQL Server 2005), я настроил два отчета. Для простоты объяснения давайте назовем ихMAIN_REPORT а такжеSUB_REPORT.

MAIN_REPORT запускает запрос, который возвращает набор областей с несколькими тегами в каждой области:

AREA    Tagname
----------
A1        T1
A1        T2
A2        T3
A3        T4

Если вы выберете одну из ячеек области, она откроетсяSUB_REPORT и передает параметр@ParentTagNames с помощьюJoin(Parameters!ResultsOfSearch.Value,","). ResultsOfSearch равно столбцу тэгов выше (пока не выяснил, как ограничить тэги только в выбранной области, но об этом я буду беспокоиться позже).

SUB_REPORT принимает переданный параметр и запрашивает массивную базу данных для тэга и возвращает минимальное, максимальное и среднее из доступных значений:

SELECT
h.TagName as TagName,
Minimum = convert(decimal(38, 2), Min(h.Value)), 
Maximum = convert(decimal(38, 2), Max(h.Value)), 
Average = convert(decimal(38, 2), Avg(h.Value)) 
FROM INSQL.Runtime.dbo.History h 
WHERE h.TagName in (@ParentTagNames)
AND h.wwVersion = 'LATEST'
AND h.wwRetrievalMode = 'Cyclic'
AND h.wwResolution = '60000'
AND h.Value > '-1.0'
AND h.DateTime >= '2009-09-01 12:00:00'
AND h.DateTime <= '2009-09-02 16:00:00'
GROUP BY h.TagName

Однако если@ParentTagNames равно более чем одному значению, он не возвращает данных. Если он равен одному тегу, он возвращает данные. Я подумал, что это как-то связано с форматированием данных в@ParentTagNames как оно прошло отMAIN_REPORT, но это, похоже, не имеет значения.

Я пробовал следующие форматы:

T1,T2,T3,T4,T5,T6
'T1','T2','T3','T4','T5','T6'

Я убедился, что мульти-значение проверяется на параметр@ParentTagNames, Google успешно подвел меня.

Кто-нибудь?

РЕДАКТИРОВАТЬ: Профилировщик магии!

exec sp_executesql N'SELECT
    h.TagName as TagName,
    Minimum = convert(decimal(38, 2), Min(h.Value)), 
    Maximum = convert(decimal(38, 2), Max(h.Value)), 
    Average = convert(decimal(38, 2), Avg(h.Value)) 
FROM INSQL.Runtime.dbo.History h 
WHERE h.TagName in (@ParentTagNames)
AND h.wwVersion = ''LATEST''
AND h.wwRetrievalMode = ''Cyclic''
--AND h.wwResolution = @Resolution
AND h.wwResolution = ''60000''
AND h.Value > ''-1.0''
--AND h.DateTime >= @StartTime
--AND h.DateTime <= @EndTime

AND h.DateTime >= ''2009-09-01 12:00:00''
AND h.DateTime <= ''2009-09-02 16:00:00''

GROUP BY h.TagName',N'@ParentTagNames nvarchar(46)',@ParentTagNames=N'M12_CPM_Filling_250.Value,M8_Filling_391.Value'

Ответы на вопрос(1)

Ваш ответ на вопрос