SET(7) | SQL Commands | SET(7) |
SET - 改變執行時引數
SET [ SESSION | LOCAL ] name { TO | = } { value | 'value' | DEFAULT } SET [ SESSION | LOCAL ] TIME ZONE { timezone | LOCAL | DEFAULT }
SET 命令修改執行時配置引數。許多在 Section 16.4 ``Run-time Configuration'' 裡面列出的執行時引數可以用 SET 在執行時設定。 (但是有些要求使用超級使用者許可權來修改,而其它有些則在伺服器或者會話 開始之後不能修改。)請注意 SET 隻影響當前會話使用的數值。
如果 SET 或者 SET SESSION
是在一個稍後退出的事務裡發出的,
那麼 SET
命令的效果將在事務回滾的之後小時。
(這個行為和PostgreSQL版本
7.3 之前的不同,
那個時候 SET
的效果在後面的錯誤之後不會回滾。)
一旦包圍它的事務提交,那麼其效果將持續到事務的結束,除非被另外一個
SET 覆蓋。
SET LOCAL 的效果只持續到當前事務結束,不管是否提交。 一個特例是在一個事務裡面的 SET 後面跟著一個 SET LOCAL:在事務結束之前只能看到 SET LOCAL 的數值,但是之後(如果事務提交),則是 SET 的值生效。
除了在 Section 16.4 ``Run-time Configuration''
裡面有文件記載的配置引數之外,
還有幾個只能用 SET
命令設定,或者是有特殊的語法的引數:
我們也可以透過呼叫函式
setseed 來設定種子:
SELECT setseed(value);
參閱 Section 8.5 ``Date/Time Types''
獲取有關時區的更多細節。
函式 set_config 提供了等效的功能。 參閱 Section 9.13 ``Miscellaneous Functions'' 。
設定模式搜尋路徑:
SET search_path TO my_schema, public;
把日期時間風格設定為傳統的 POSTGRES 風格, with ``day before month'' input convention:
SET datestyle TO postgres, dmy;
把時區設定為加州伯克力,
使用雙引號儲存時區聲明裡大寫字元的屬性
(注意這裡的日期/時間格式是
PostgreSQL):
SET TIME ZONE 'PST8PDT'; SELECT current_timestamp AS today; today ------------------------------- 2003-04-29 15:02:01.218622-07
SET TIME ZONE 擴充套件了在 SQL 標準裡定義的語法。 標準只允許有一個數字時區偏移, 而 PostgreSQL 還允許完整更靈活的時區宣告。 所有其它的 SET 特性都是 PostgreSQL 擴充套件。
RESET [reset(7)], SHOW [show(l)]
Postgresql 中文網站 何偉平 <laser@pgsqldb.org>
本頁面中文版由中文
man 手冊頁計劃提供。
中文 man
手冊頁計劃:https://github.com/man-pages-zh/manpages-zh
2003-11-02 | SQL - Language Statements |