在PostgreSQL中,我可以从表的查询中选择数据。例如,我想使用for循环从t1显示实体名称。
DO
$do$
DECLARE
e varchar;
BEGIN
FOR e IN (SELECT entityname
FROM t1)
LOOP
raise notice 'Value: %', e;
END LOOP;
END
$do$;
但是如果我已经有了entityname列表,我只想显示它。什么是正确的方法,我尝试使用
DO
$do$
DECLARE
e varchar;
BEGIN
FOR e IN ('t1','t2')
LOOP
raise notice 'Value: %', e;
END LOOP;
END
$do$;
但是它给出了错误
ERROR: syntax error at or near "'t1'"
LINE 6: FOR e IN ('t1','t2')
这样做的正确方法是什么?
答案 0 :(得分:0)
正确的语句是FOREACH target IN ARRAY,它遍历一个数组:
FOREACH target [ SLICE number ] IN ARRAY expression LOOP
statements
END LOOP;
同样在你的情况下:
DO $do$ DECLARE e varchar;
BEGIN
FOREACH e IN ARRAY ARRAY['t1','t2'] LOOP
raise notice 'Value: %', e;
END LOOP;
END $do$;