#sql #variables #hana
#sql #переменные #hana
Вопрос:
Я пытаюсь использовать переменную в качестве входных данных для WHERE
условия, имеющего IN
предложение, используя SAP HANA.
Например:
DO
BEGIN
DECLARE a VARCHAR(100) = '1000,1001';
DECLARE b NVARCHAR(100) ARRAY = ARRAY('1000','1001');
DECLARE c TABLE (valuelist NVARCHAR(100));
--SELECT '1001' INTO valuelist FROM :c;
--:c.INSERT('1001','1000');
DECLARE e NVARCHAR(100) = ' ''1000'',''1001'' ';
DECLARE f NVARCHAR(100) = '"STATIONID" IN (''1000'',''1001'')';
select
STATIONID
from MY_TABLE
where STATIONID IN ('1000','1001') -- working fine, but want to use a variable here
-- where STATIONID IN (:a)
-- where STATIONID IN (:b)
-- where STATIONID IN :c
-- where :f
order by STATIONID;
END
Однако все мои попытки, некоторые из которых вы можете увидеть выше, заканчиваются неудачей при наличии нескольких значений в моем состоянии. STATIONID
на самом деле это строковое поле.
Есть какие-либо подсказки о том, как это сделать?
Ответ №1:
Наконец-то я понял, как я могу использовать a variable array
вместе с a variable table
, используя UNNEST
. Это работает просто отлично:
DO
BEGIN
DECLARE STATION_TMP_ARRAY NVARCHAR(10) ARRAY = ARRAY('1000','1001','1002','1003','1004');
DECLARE STATION_TMP_TABLE TABLE ("tmp_stationid" NVARCHAR(10)) = UNNEST(:STATION_TMP_ARRAY) AS ("tmp_stationid");
select
STATIONID
from MY_TABLE
where "STATIONID" IN (SELECT "tmp_stationid" FROM :STATION_TMP_TABLE)
order by STATIONID;
END