BEGIN
功能描述
BEGIN可以用于开始一个匿名块,也可以用于开始一个事务。
匿名块是能够动态地创建和执行过程代码的结构,而不需要以持久化的方式将代码作为数据库对象储存在数据库中。
注意事项
无。
语法格式
- 开启匿名块。
1 2 3 4 5
[DECLARE [declare_statements]] BEGIN execution_statements END; /
- 开启事务。
1 2 3 4 5 6 7
BEGIN [ WORK | TRANSACTION ] [ { ISOLATION LEVEL { READ COMMITTED | SERIALIZABLE | REPEATABLE READ } | { READ WRITE | READ ONLY } } [, ...] ];
参数说明
- declare_statements
声明变量,包括变量名和变量类型,如“sales_cnt int”。
- execution_statements
匿名块中要执行的语句。
取值范围:已存在的函数名称。
- WORK | TRANSACTION
BEGIN语法格式中的可选关键字,没有实际作用。
- ISOLATION LEVEL
指定事务隔离级别,它决定当一个事务中存在其他并发运行事务时它能够看到什么数据。
在事务中第一个数据修改语句(INSERT,DELETE,UPDATE,FETCH,COPY)执行之后,事务隔离级别就不能再次设置。
取值范围:
- READ COMMITTED:读已提交隔离级别,只能读到已经提交的数据,而不会读到未提交的数据。这是缺省值。
- READ UNCOMMITTED:读未提交隔离级别,可能会读到未提交的数据。提供这个隔离级别可用于在存在某协调节点CN故障等情况下应急使用,建议这种隔离级别下仅作只读操作,避免造成数据不一致。
- 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; /