首頁 >數據庫 >mysql教程 > 正文

詳細講解mysql全局變量與局部變量

轉載2020-01-27 20:39:040265
第11期線上培訓班

通常在服務器啟動時,會將每個全局變量初始化為其默認值(我們可以通過命令行或選項文件中指定的選項更改這些默認值),然后服務器還為每個連接的客戶端維護一組會話變量,客戶端的會話變量在連接時使用相應全局變量的當前值初始化。

舉例說明如下:

在服務器啟動時會初始化一個名為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中文網其它相關文章!

php中文網最新課程二維碼
  • 相關標簽:mysql 全局變量 局部變量
  • 本文轉載于:博客園,如有侵犯,請聯系[email protected]刪除
  • 相關文章

    相關視頻


    網友評論

    文明上網理性發言,請遵守 新聞評論服務協議

    我要評論
  • 專題推薦

    推薦視頻教程
  • 動力節點mysql基礎視頻教程動力節點mysql基礎視頻教程
  • 數據庫mysql視頻教程數據庫mysql視頻教程
  • MySQLi面向過程極速入門MySQLi面向過程極速入門
  • MySQL高級進階視頻教程MySQL高級進階視頻教程
  • 視頻教程分類
    3d试机号绕胆图