Службы 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'