DO — 执行匿名代码块
DO [ LANGUAGElang_name]code
DO 执行匿名代码块,或者换句话说,执行过程语言中的瞬态匿名函数。
代码块被视为一个没有参数的函数体,返回 void。它被解析并执行一次。
可选的 LANGUAGE 子句可以在代码块之前或之后编写。
代码要执行的过程语言代码。这必须指定为字符串文字,就像在 CREATE FUNCTION 中一样。建议使用美元引号引用的文字。
lang_name代码所用过程语言的名称。如果省略,则默认为 plpgsql。
要使用的过程语言必须已经通过 CREATE EXTENSION 安装到当前数据库中。 plpgsql 默认安装,但其他语言没有安装。
用户必须具有过程语言的 USAGE 权限,或者如果语言不受信任,则必须是超级用户。这与用该语言创建函数的权限要求相同。
如果 DO 在事务块中执行,则过程代码不能执行事务控制语句。只有当 DO 在其自己的事务中执行时,才允许事务控制语句。
将架构 public 中所有视图上的所有权限授予角色 webuser
DO $$DECLARE r record;
BEGIN
FOR r IN SELECT table_schema, table_name FROM information_schema.tables
WHERE table_type = 'VIEW' AND table_schema = 'public'
LOOP
EXECUTE 'GRANT ALL ON ' || quote_ident(r.table_schema) || '.' || quote_ident(r.table_name) || ' TO webuser';
END LOOP;
END$$;
SQL 标准中没有 DO 语句。
如果您在文档中看到任何不正确、与您对特定功能的体验不符或需要进一步澄清的内容,请使用 此表单 报告文档问题。