# 做
执行一个匿名代码块
# 提要
DO [ LANGUAGE lang_name ] code
# 描述
做
执行匿名代码块,或者换句话说,执行过程语言中的临时匿名函数。
代码块被视为没有参数的函数体,返回无效的
.它被解析并执行一次。
可选的语言
子句可以在代码块之前或之后编写。
# 参数
密码
要执行的过程语言代码。必须将其指定为字符串文字,如中所示创建函数
.建议使用美元报价文字。
郎朗的名字
编写代码的过程语言的名称。如果省略,则默认为plpgsql
.
# 笔记
要使用的过程语言必须已通过安装在当前数据库中创建扩展
. plpgsql
默认情况下安装,但其他语言不安装。
用户必须具有用法
程序语言的权限,如果该语言不受信任,则必须是超级用户。这与在语言中创建函数的权限要求相同。
如果做
在事务块中执行,则过程代码无法执行事务控制语句。只有在以下情况下才允许使用事务控制语句:做
在自己的事务中执行。
# 例子
授予架构中所有视图的所有权限平民的
扮演网络用户
:
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标准中的语句。