ALTER SESSION

功能描述

ALTER SESSION命令用于定义或修改那些对当前会话有影响的条件或参数。修改后的会话参数会一直保持,直到断开当前会话。

注意事项

  • 如果执行SET TRANSACTION之前没有执行START TRANSACTION,则事务立即结束,命令无法显示效果。
  • 可以用START TRANSACTION里面声明所需要的transaction_mode(s)的方法来避免使用SET TRANSACTION。

语法格式

  • 设置会话的事务参数。

    1. ALTER SESSION SET [ SESSION CHARACTERISTICS AS ] TRANSACTION
    2. { ISOLATION LEVEL { READ COMMITTED } | { READ ONLY | READ WRITE } } [, ...] ;
  • 设置会话的其他运行时参数。

    1. ALTER SESSION SET
    2. {{config_parameter { { TO | = } { value | DEFAULT }
    3. | FROM CURRENT }}
    4. | TIME ZONE time_zone
    5. | CURRENT_SCHEMA schema
    6. | NAMES encoding_name
    7. | ROLE role_name PASSWORD 'password'
    8. | SESSION AUTHORIZATION { role_name PASSWORD 'password' | DEFAULT }
    9. | XML OPTION { DOCUMENT | CONTENT }
    10. } ;

参数说明

修改会话涉及到的参数说明请参见SET语法中的参数说明

示例

  1. -- 创建模式ds
  2. postgres=# CREATE SCHEMA ds;
  3. --设置模式搜索路径。
  4. postgres=# SET SEARCH_PATH TO ds, public;
  5. --设置日期时间风格为传统的POSTGRES风格(日在月前)。
  6. postgres=# SET DATESTYLE TO postgres, dmy;
  7. --设置当前会话的字符编码为UTF8
  8. postgres=# ALTER SESSION SET NAMES 'UTF8';
  9. --设置时区为加州伯克利。
  10. postgres=# SET TIME ZONE 'PST8PDT';
  11. --设置时区为意大利。
  12. postgres=# SET TIME ZONE 'Europe/Rome';
  13. --设置当前模式。
  14. postgres=# ALTER SESSION SET CURRENT_SCHEMA TO tpcds;
  15. --设置XML OPTIONDOCUMENT
  16. postgres=# ALTER SESSION SET XML OPTION DOCUMENT;
  17. --创建角色joe,并设置会话的角色为joe
  18. postgres=# CREATE ROLE joe WITH PASSWORD 'Bigdata@123';
  19. postgres=# ALTER SESSION SET SESSION AUTHORIZATION joe PASSWORD 'Bigdata@123';
  20. --切换到默认用户。
  21. postgres=> ALTER SESSION SET SESSION AUTHORIZATION default;
  22. --删除ds模式。
  23. postgres=# DROP SCHEMA ds;
  24. --删除joe
  25. postgres=# DROP ROLE joe;

相关链接

SET