mysql中局部变量说法正确的是_mysql全局变量和局部变量
全局變量和局部變量
在服務(wù)器啟動時,會將每個全局變量初始化為其默認值(可以通過命令行或選項文件中指定的選項更改這些默認值)。然后服務(wù)器還為每個連接的客戶端維護一組會話變量,客戶端的會話變量在連接時使用相應(yīng)全局變量的當前值初始化。
舉一個例子,在服務(wù)器啟動時會初始化一個名為default_storage_engine,作用范圍為GLOBAL的系統(tǒng)變量。之后每當有一個客戶端連接到該服務(wù)器時,服務(wù)器都會單獨為該客戶端分配一個名為default_storage_engine,作用范圍為SESSION的系統(tǒng)變量,該作用范圍為SESSION的系統(tǒng)變量值按照當前作用范圍為GLOBAL的同名系統(tǒng)變量值進行初始化。
很顯然,通過啟動選項設(shè)置的系統(tǒng)變量的作用范圍都是GLOBAL的,也就是對所有客戶端都有效的,因為在系統(tǒng)啟動的時候還沒有客戶端程序連接進來呢。了解了系統(tǒng)變量的GLOBAL和SESSION作用范圍之后,我們再看一下在服務(wù)器程序運行期間通過客戶端程序設(shè)置系統(tǒng)變量的語法:
SET [GLOBAL|SESSION] 系統(tǒng)變量名 = 值;
或者寫成這樣也行:
SET [@@(GLOBAL|SESSION).]var_name = XXX;
比如我們想在服務(wù)器運行過程中把作用范圍為GLOBAL的系統(tǒng)變量default_storage_engine的值修改為MyISAM,也就是想讓之后新連接到服務(wù)器的客戶端都用MyISAM作為默認的存儲引擎,那我們可以選擇下邊兩條語句中的任意一條來進行設(shè)置:
語句一:SET GLOBAL default_storage_engine = MyISAM;
語句二:SET @@GLOBAL.default_storage_engine = MyISAM;
如果只想對本客戶端生效,也可以選擇下邊三條語句中的任意一條來進行設(shè)置:
語句一:SET SESSION default_storage_engine = MyISAM;
語句二:SET @@SESSION.default_storage_engine = MyISAM;
語句三:SET default_storage_engine = MyISAM;
從上邊的語句三也可以看出,如果在設(shè)置系統(tǒng)變量的語句中省略了作用范圍,默認的作用范圍就是SESSION。也就是說SET 系統(tǒng)變量名 = 值和SET SESSION 系統(tǒng)變量名 = 值是等價的。
查看不同作用范圍的系統(tǒng)變量
既然系統(tǒng)變量有作用范圍之分,那我們的SHOW VARIABLES語句查看的是什么作用范圍的系統(tǒng)變量呢?
答:默認查看的是SESSION作用范圍的系統(tǒng)變量。
當然我們也可以在查看系統(tǒng)變量的語句上加上要查看哪個作用范圍的系統(tǒng)變量,就像這樣:
SHOW [GLOBAL|SESSION] VARIABLES [LIKE 匹配的模式];
總結(jié)
以上是生活随笔為你收集整理的mysql中局部变量说法正确的是_mysql全局变量和局部变量的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: hp laser103 属性没有配置项_
- 下一篇: mysql 行列转换 动态_mysql