0

我需要在 BI Publisher 报表上有多个选择参数。我将参数传递给一个函数,该函数将逗号分隔的值列表转换为表。然后,我在 where 子句的“IN”语句中使用 csv 解析器函数中的表。它看起来像下面...

select * from table(my_report_function(my_csv_parser_function(:Parameter))

当我在 SQL Developer 中运行它时,它工作正常。问题是,当 BI Publisher 传递参数时,它会将每个逗号解释为单独的参数,因此我得到参数数量无效的错误。我怎样才能阻止它这样做,或者是否有更好的方法来处理传递给函数的多个选择参数?

4

1 回答 1

0

是的,参数在 sql 查询中作为 line 传递,以便稍后在 sql 查询中使用此参数。

在您的情况下,例如:

select * from table(my_report_function(my_csv_parser_function(1,2,3,4,5,6))

相反,您可以在您的 sql 查询中使用此参数。以我为例,它是:

select *
from dev_dmart.FCT_CURRENCY_RATE
WHERE FROM_CURRENCY_CD = 840
and TO_CURRENCY_CD IN (:multiple_select_parameter_list)

在你的情况下,它可能是这样的:

select * from table(my_report_function())
where field in (:Parameter)

或者,您可以在 Publisher 中的“数据前”上创建事件触发器并在那里调用函数,该函数将计算数据并将其插入 TABLE(例如 PRECALCULATED_DATA)。然后在报告中您可以使用查询:

select * from PRECALCULATED_DATA where field in (:Parameter)

于 2014-11-24T10:57:49.417 回答