首頁 > 資料庫 > mysql教程 > 詳細講解mysql全域變數與局部變數

詳細講解mysql全域變數與局部變數

王林
發布: 2020-01-27 20:39:04
轉載
2667 人瀏覽過

詳細講解mysql全域變數與局部變數

通常在伺服器啟動時,會將每個全域變數初始化為其預設值(我們可以透過命令列或選項檔中指定的選項來變更這些預設值),然後伺服器也為每個連線的客戶端維護一組會話變量,客戶端的會話變數在連線時使用對應全域變數的目前值初始化。

舉例說明如下:

在伺服器啟動時會初始化一個名為default_storage_engine,作用範圍為GLOBAL的系統變量,之後每當有一個客戶端連接到該伺服器時,伺服器都會單獨為該客戶端指派一個名為default_storage_engine,作用範圍為SESSION的系統變量,該作用範圍為SESSION的系統變數值依照目前作用範圍為GLOBAL的同名系統變數值進行初始化。

(免費學習影片教學推薦:mysql影片教學

很顯然,透過啟動選項設定的系統變數的作用範圍都是GLOBAL的,也就是對所有客戶端都有效的,因為在系統啟動的時候還沒有客戶端程式連接進來。在了解了系統變數的GLOBAL和SESSION作用範圍之後,我們再看一下在伺服器程式運行期間透過客戶端程式設定係統變數的語法:

SET [GLOBAL|SESSION] 系统变量名 = 值;
登入後複製

或如下寫法:

SET [@@(GLOBAL|SESSION).]var_name = XXX;
登入後複製

例如我們要在伺服器運作過程中把作用範圍為GLOBAL的系統變數default_storage_engine的值修改成MyISAM,也就是想讓之後新連接到伺服器的客戶端都用MyISAM作為預設的儲存引擎,那我們可以選擇下邊兩條語句中的任一條來進行設定:

語句一:

SET GLOBAL default_storage_engine = MyISAM;
登入後複製

語句二:

SET @@GLOBAL.default_storage_engine = MyISAM;
登入後複製

如果只想對本客戶端生效,也可以選擇下邊三條語句中的任一條來進行設定:

語句一:

SET SESSION default_storage_engine = MyISAM;
登入後複製

語句二:

SET @@SESSION.default_storage_engine = MyISAM;
登入後複製

語句三:

SET default_storage_engine = MyISAM;
登入後複製

從上邊的語句三也可以看出,如果在設定係統變數的語句中省略了作用範圍,預設的作用範圍就是SESSION。也就是說SET 系統變數名稱 = 值和SET SESSION 系統變數名稱 = 值是等價的。

看看不同作用範圍的系統變數

既然系統變數有作用範圍之分,那我們的SHOW VARIABLES語句查看的是什麼作用範圍的系統變數呢?

答案:預設查看的是SESSION作用範圍的系統變數。

當然我們也可以在查看系統變數的語句上加上要查看哪個作用範圍的系統變量,就像這樣:

SHOW [GLOBAL|SESSION] VARIABLES [LIKE 匹配的模式];
登入後複製

相關文章教學推薦: mysql教學

以上是詳細講解mysql全域變數與局部變數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:cnblogs.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板