Redrock Postgres 搜索 英文
版本: 9.3 / 9.4 / 9.5 / 9.6 / 10 / 11 / 12 / 13 / 14 / 15 / 16 / 17

DO

DO — 执行匿名代码块

语法

DO [ LANGUAGE lang_name ] code

说明

DO 执行匿名代码块,或换句话说,在过程语言中执行瞬态匿名函数。

代码块被视为没有参数的函数的主体,返回 void。它被解析并执行一次。

可选的 LANGUAGE 子句可以在代码块之前或之后编写。

参数

code

要执行的过程语言代码。这必须指定为字符串常量,就像在 CREATE FUNCTION 中一样。建议使用带美元符号的文本常量。

lang_name

代码所用过程语言的名称。如果省略,默认值为 plpgsql

注释

将要使用的过程语言必须已经被安装到当前数据库中,通过 CREATE EXTENSIONplpgsql 是默认安装的,但其他语言却没有安装。

用户必须拥有针对过程语言的 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 语句。

另请参阅

CREATE LANGUAGE