通过变量选择计算视图时出错

Error while selecting the calculation view through variables

我在通过变量从计算视图读取时遇到一个有趣的问题...代码如下:

do begin
declare lv_ww nvarchar(6);
declare lv_quarter nvarchar(6);

select "WORKWEEK","QUARTER" INTO lv_ww,lv_quarter from "ABC"."TABLE1";

select count(*) from "_SYS_BIC"."CID" (PLACEHOLDER."IP_SNAPSHOTWW" => :lv_ww,PLACEHOLDER."IP_QUARTER" => :lv_quarter);
end;

我收到列存储错误、搜索 table 错误、计划运算符在 select 计数 (*) 行中失败。所以基本上是内存不足的问题,因为它占用了超过 15 GB 的内存。

现在我将对 lv_ww = '202114' 和 lv_quarter = '2021Q2'

的值进行硬编码
do begin
declare lv_ww nvarchar(6) default '202114';
declare lv_quarter nvarchar(6) default '2021Q2';

select count(*) from "_SYS_BIC"."CID" (PLACEHOLDER."IP_SNAPSHOTWW" => :lv_ww,PLACEHOLDER."IP_QUARTER" => :lv_quarter);
end;

它运行得非常好,只需要 0.012 GB。

注意 - lv_ww 和 lv_quarter 从 TABLE1 计算时非常好,给我们的值是 (lv_ww = 202114 and lv_quarter = 2021Q2)

如果您需要任何其他详细信息,请告诉我,如果有任何解决方案,请赐教。

与我给出的答案相同 here :

好吧,我在这里冒昧地说:不同的执行 time/memory 可能是由于不同的执行计划。由于语句之间的区别在于第一种情况下选择的值在查询编译时是未知的,但在另一种情况下是已知的,这可能是不同执行计划的原因。

你可能想检查这个理论!

解决此问题的一种方法是使用 BIND_AS_VALUE SQLScript 函数 (https://help.sap.com/viewer/de2486ee947e43e684d39702027f8a94/2.0.05/en-US/0b2958ee0426496f9c084c92b14993f1.html)