更新时间:2024-11-12 GMT+08:00
分享

BEGIN

功能描述

BEGIN可以用于开始一个匿名块,也可以用于开始一个事务。

匿名块是能够动态地创建和执行过程代码的结构,而不需要以持久化的方式将代码作为数据库对象储存在数据库中。

注意事项

无。

语法格式

  • 开启匿名块。
    [DECLARE [declare_statements]] 
    BEGIN
    execution_statements
    END;
    /

  • 开启事务。
    BEGIN [ WORK | TRANSACTION ]
      [ 
        { 
           ISOLATION LEVEL { READ COMMITTED | READ UNCOMMITTED | SERIALIZABLE | REPEATABLE READ }
           | { READ WRITE | READ ONLY }
          } [, ...] 
      ];

参数说明

  • declare_statements

    声明变量,包括变量名和变量类型,如“sales_cnt int”。

  • execution_statements

    匿名块中要执行的语句。

    取值范围:DML操作(数据操纵操作:select、insert、delete、update)或系统表中已注册的函数名称。

  • WORK | TRANSACTION

    BEGIN语法格式中的可选关键字,没有实际作用。

  • ISOLATION LEVEL

    指定事务隔离级别,它决定当一个事务中存在其他并发运行事务时它能够看到什么数据。

    在事务中第一个数据修改语句(INSERT,DELETE,UPDATE,FETCH,COPY)执行之后,事务隔离级别就不能再次设置。

    取值范围:

    • READ COMMITTED:读已提交隔离级别,只能读到已经提交的数据,而不会读到未提交的数据。这是缺省值。
    • READ UNCOMMITTED:读未提交隔离级别,指定后的行为和READ COMMITTED行为一致。
    • REPEATABLE READ:可重复读隔离级别,仅仅看到事务开始之前提交的数据,它不能看到未提交的数据,以及在事务执行期间由其它并发事务提交的修改。
    • SERIALIZABLE:目前功能上不支持此隔离级别,设置该隔离级别时,等价于REPEATABLE READ。
  • READ WRITE | READ ONLY

    指定事务访问模式(读/写或者只读)。

示例

  • 开启事务
    --建表并插入数据。
    gaussdb=# CREATE TABLE tbl_test1(col1 int, col2 int);
    gaussdb=# INSERT INTO tbl_test1 VALUES (1,1), (2,2), (3,3);
    
    --以默认方式启动事务。
    gaussdb=# BEGIN;
    INSERT INTO tbl_test1 VALUES (4,4);
    END;
    
    --以隔离级别为REPEATABLE READ方式启动事务。
    gaussdb=# BEGIN ISOLATION LEVEL REPEATABLE READ; 
    SELECT * FROM tbl_test1; 
    END;
    
    --删除表。
    gaussdb=# DROP TABLE tbl_test1;
  • 匿名块。
    1
    2
    3
    4
    5
    --使用匿名块输出字符串。
    gaussdb=# BEGIN
    dbe_output.print_line('Hello');
    END;
    /
    

相关链接

START TRANSACTION

相关文档