全局變數和局部變數 在伺服器啟動時,會將每個全局變數初始化為其預設值(可以通過命令行或選項文件中指定的選項更改這些預設值)。然後伺服器還為每個連接的客戶端維護一組會話變數,客戶端的會話變數在連接時使用相應全局變數的當前值初始化。 舉一個例子,在伺服器啟動時會初始化一個名為default_storag ...
全局變數和局部變數
在伺服器啟動時,會將每個全局變數初始化為其預設值(可以通過命令行或選項文件中指定的選項更改這些預設值)。然後伺服器還為每個連接的客戶端維護一組會話變數,客戶端的會話變數在連接時使用相應全局變數的當前值初始化。
舉一個例子,在伺服器啟動時會初始化一個名為default_storage_engine,作用範圍為GLOBAL的系統變數。之後每當有一個客戶端連接到該伺服器時,伺服器都會單獨為該客戶端分配一個名為default_storage_engine,作用範圍為SESSION的系統變數,該作用範圍為SESSION的系統變數值按照當前作用範圍為GLOBAL的同名系統變數值進行初始化。
很顯然,通過啟動選項設置的系統變數的作用範圍都是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 匹配的模式];