0

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

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;

我在选择计数(*)行中收到列存储错误、搜索表错误、计划运算符失败。所以基本上是内存不足的问题,因为它占用了超过 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。

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

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

4

1 回答 1

0

与我在这里给出的答案相同:

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

你可能想检查这个理论!

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

于 2021-04-10T23:17:00.650 回答