更新时间:2025-09-12 GMT+08:00
分享

START TRANSACTION

功能描述

通过START TRANSACTION启动事务。如果声明了隔离级别、读写模式,那么新事务就使用这些特性,类似执行了SET TRANSACTION

语法格式

格式一:START TRANSACTION格式

START TRANSACTION
  [ 
    { 
       ISOLATION LEVEL { READ COMMITTED | READ UNCOMMITTED | SERIALIZABLE | REPEATABLE READ }
       | { READ WRITE | READ ONLY } | WITH CONSISTENT SNAPSHOT
     } [ ...] 
  ];

格式二:BEGIN格式

BEGIN [ WORK | TRANSACTION ]
  [ 
    { 
       ISOLATION LEVEL { READ COMMITTED | READ UNCOMMITTED | SERIALIZABLE | REPEATABLE READ }
       | { READ WRITE | READ ONLY }
      } [ ...] 
  ];

参数说明

  • WORK | TRANSACTION

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

  • ISOLATION LEVEL

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

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

    取值范围:

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

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

  • WITH CONSISTENT SNAPSHOT

    仅在可重复读隔离级别下生效,开启事务时即生成快照,其余隔离级别不生效,并产生告警。

    如果关闭此参数,在可重复读隔离级别,事务中第一个数据修改语句(DML、DDL或DCL)执行之后,即会建立事务的一致性读快照。支持多次设置此参数。

示例

--创建SCHEMA。
m_db=# CREATE SCHEMA tpcds;

--创建表tpcds.reason。
m_db=# CREATE TABLE tpcds.reason (c1 int, c2 int);

--以默认方式启动事务。
m_db=# START TRANSACTION;
m_db=# SELECT * FROM tpcds.reason;
m_db=# COMMIT;

--以默认方式启动事务。
m_db=# BEGIN;
m_db=# SELECT * FROM tpcds.reason;
m_db=# COMMIT;

--以隔离级别为READ COMMITTED,读/写方式启动事务。
m_db=# START TRANSACTION ISOLATION LEVEL READ COMMITTED READ WRITE;
m_db=# SELECT * FROM tpcds.reason;
m_db=# COMMIT;

--可重复读隔离级别下,带WITH CONSISTENT SNAPSHOT开启事务。
m_db=# START TRANSACTION WITH CONSISTENT SNAPSHOT ISOLATION LEVEL REPEATABLE READ;
m_db=# SELECT * FROM tpcds.reason;
m_db=# COMMIT;

--非可重复读隔离级别下,带WITH CONSISTENT SNAPSHOT开启事务。
m_db=# START TRANSACTION WITH CONSISTENT SNAPSHOT ISOLATION LEVEL READ COMMITTED;
WARNING:  WITH CONSISTENT SNAPSHOT was ignored because this phrase can only be used with REPEATABLE READ isolation level.
m_db=# SELECT * FROM tpcds.reason;
m_db=# COMMIT;

--删除表tpcds.reason。
m_db=# DROP TABLE tpcds.reason;

--删除SCHEMA。
m_db=# DROP SCHEMA tpcds;

相关链接

COMMITROLLBACKSET TRANSACTION

相关文档