DO — 执行匿名代码块
DO [ LANGUAGElang_name
]code
DO
执行一个匿名代码块,或者换句话说,是一个用过程语言编写的瞬时匿名函数。
代码块被视为一个没有参数且返回 void
的函数体。它会被解析并执行一次。
可选的 LANGUAGE
子句可以写在代码块之前或之后。
code
要执行的过程语言代码。必须将其指定为字符串字面量,就像在 CREATE FUNCTION
中一样。建议使用美元符号引用的字面量。
lang_name
代码所用的过程语言的名称。如果省略,则默认值为 plpgsql
。
要使用的过程语言必须已经通过 CREATE EXTENSION
安装到当前数据库中。 plpgsql
默认安装,但其他语言则不是。
用户必须对该过程语言具有 USAGE
权限,或者如果该语言不受信任,则必须是超级用户。 这与使用该语言创建函数的要求相同。
如果在事务块中执行 DO
,则过程代码不能执行事务控制语句。 只有在 DO
在自己的事务中执行时,才允许使用事务控制语句。
授予角色 webuser
在模式 public
中的所有视图的所有权限
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
语句。
如果您在文档中发现任何不正确、与您使用特定功能的体验不符或需要进一步澄清的内容,请使用此表单报告文档问题。