如何从pgsql中的列表中选择数据

时间:2015-12-08 06:11:38

标签: sql postgresql plpgsql

在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')

这样做的正确方法是什么?

1 个答案:

答案 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$;