功能描述
为当前事务设置特性。它对后面的事务没有影响。事务特性包括事务隔离级别、事务访问模式(读/写或者只读)。
注意事项
无。
语法格式
设置事务的隔离级别、读写模式。
{ SET [ LOCAL ] TRANSACTION|SET SESSION CHARACTERISTICS AS TRANSACTION }
{ ISOLATION LEVEL { READ COMMITTED | READ UNCOMMITTED | SERIALIZABLE | REPEATABLE READ }
| { READ WRITE | READ ONLY } } [, ...]
参数说明
-
LOCAL
声明该命令只在当前事务中有效。
-
SESSION
声明这个命令只对当前会话起作用。
取值范围:字符串,要符合标识符的命名规范。
-
ISOLATION_LEVEL_CLAUSE
指定事务隔离级别,该参数决定当一个事务中存在其他并发运行事务时能够看到什么数据。
说明:
- 在事务中第一个数据修改语句(INSERT,DELETE,UPDATE,FETCH,COPY)执行之后,事务隔离级别就不能再次设置。取值范围:
- READ COMMITTED:读已提交隔离级别,只能读到已经提交的数据,而不会读到未提交的数据。这是缺省值。
- READ UNCOMMITTED:读未提交隔离级别,可能会读到未提交的数据。建议这种隔离级别下仅作只读操作,避免造成数据不一致。
- REPEATABLE READ:可重复读隔离级别,仅仅能看到事务开始之前提交的数据,不能看到未提交的数据,以及在事务执行期间由其它并发事务提交的修改。
- SERIALIZABLE:openGauss目前功能上不支持此隔离级别,等价于REPEATABLE READ。
-
READ WRITE | READ ONLY
指定事务访问模式(读/写或者只读)。
示例
--开启一个事务,设置事务的隔离级别为READ COMMITTED,访问模式为READ ONLY。
postgres=# START TRANSACTION;
postgres=# SET LOCAL TRANSACTION ISOLATION LEVEL READ COMMITTED READ ONLY;
postgres=# COMMIT;
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
文集目录
暂无数据