START TRANSACTION
功能描述
通过START TRANSACTION启动事务。如果声明了隔离级别、读写模式,那么新事务就使用这些特性,类似执行了SET TRANSACTION。
注意事项
无。
语法格式
格式一:START TRANSACTION格式
1 2 3 4 5 6 7 |
START TRANSACTION [ { ISOLATION LEVEL { READ COMMITTED | READ UNCOMMITTED | SERIALIZABLE | REPEATABLE READ } | { READ WRITE | READ ONLY } } [, ...] ]; |
格式二:BEGIN格式
1 2 3 4 5 6 7 |
BEGIN [ WORK | TRANSACTION ] [ { ISOLATION LEVEL { READ COMMITTED | READ UNCOMMITTED | SERIALIZABLE | REPEATABLE READ } | { READ WRITE | READ ONLY } } [, ...] ]; |
参数说明
参数 |
描述 |
取值范围 |
---|---|---|
WORK | TRANSACTIO |
BEGIN格式中的可选关键字,对操作没有影响。 |
- |
ISOLATION LEVEL |
指定事务隔离级别,该参数决定当一个事务中存在其他并发运行事务时能够看到什么数据。
说明:
在事务中第一个数据修改语句(INSERT,DELETE,UPDATE,FETCH,COPY)执行之后,事务隔离级别就不能再次设置。 |
|
READ WRITE | READ ONLY |
指定事务访问模式。 |
读写模式或者只读模式。 |
示例
- 以默认方式启动事务:
1 2 3
START TRANSACTION; SELECT * FROM tpcds.reason; END;
- 以隔离级别为READ COMMITTED,读/写方式启动事务:
1 2 3
START TRANSACTION ISOLATION LEVEL READ COMMITTED READ WRITE; SELECT * FROM tpcds.reason; COMMIT;