作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 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$;
但是如果我已经有了实体名称列表并且我只想显示它。什么是正确的方法,我尝试使用
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')
执行此操作的正确方法是什么?
最佳答案
正确的说法是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$;
关于sql - 如何从pgsql中的列表中选择数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34149190/
我是一名优秀的程序员,十分优秀!