亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Mysql系統(tǒng)變量與狀態(tài)變量詳細介紹

 更新時間:2022年09月27日 11:34:45   作者:Java面試365  
這篇文章主要介紹了Mysql系統(tǒng)變量與狀態(tài)變量詳細介紹,能夠在程序運行過程中影響Mysql程序行為的變量稱之為系統(tǒng)變量,想了解更多相關內容的小伙伴可以參考下面文章內容

系統(tǒng)變量

什么是Mysql系統(tǒng)變量

能夠在程序運行過程中影響Mysql程序行為的變量稱之為系統(tǒng)變量。

在Mysql中存在多個系統(tǒng)變量,可以使用show variables查看,如果直接執(zhí)行得到的結果是查詢了所有的系統(tǒng)變量,所以這個命令支持模糊匹配,

演示如下:

### 模糊搜索系統(tǒng)變量中包含conn的所有變量,精確匹配時值不包含%
mysql> show variables like '%conn%';
+-----------------------------------------------+-----------------+
| Variable_name                                 | Value           |
+-----------------------------------------------+-----------------+
| character_set_connection                      | utf8            |
| collation_connection                          | utf8_general_ci |
| connect_timeout                               | 10              |
| disconnect_on_expired_password                | ON              |
| init_connect                                  |                 |
| max_connect_errors                            | 100             |
| max_connections                               | 400             |
| max_user_connections                          | 0               |
| performance_schema_session_connect_attrs_size | 512             |
+-----------------------------------------------+-----------------+

設置系統(tǒng)變量

設置系統(tǒng)變量其實在上篇已經聊過兩種通過啟動項配置以及my.cnf配置文件配置,演示如下

my.cnf設置配置

my.cnf文件配置;

[mysqld]
datadir=/usr/local/mysql-5.7.26/data
default-storage-engine=MyISAM
max-connections=10
### 其它配置省略

客戶端讀取:

mysql> show variables like '%datadir%';
+---------------+-------------------------------+
| Variable_name | Value                         |
+---------------+-------------------------------+
| datadir       | /usr/local/mysql-5.7.26/data/ |
+---------------+-------------------------------+
1 row in set (0.00 sec)

mysql> show variables like '%default-storage-engine%';
Empty set (0.01 sec)
#### 注意搜索系統(tǒng)變量名字的區(qū)別?。。?
mysql> show variables like '%default_storage_engine%';
+------------------------+--------+
| Variable_name          | Value  |
+------------------------+--------+
| default_storage_engine | MyISAM |
+------------------------+--------+
1 row in set (0.00 sec)

注意:在MySQL客戶端讀取配置時所有系統(tǒng)變量采用的是下劃線(僅支持下劃線),而在配置文件My.cnf或者啟動配置項中采用中劃線或者下劃線是等價的,一定要注意區(qū)分?。。。。。?。

啟動項配置

服務端啟動配置

###?root用戶執(zhí)行采用配置--user=root,非root用戶不用
mysqld?--user=root?--max-connections=111

客戶端查詢系統(tǒng)變量

mysql> show variables like '%max_connections%';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| max_connections | 111   |
+-----------------+-------+
1 row in set (0.00 sec)

這兩種方法都可以修改系統(tǒng)變量,但是缺點也是存在的

  • 修改完需要重啟服務端才可以生效。
  • 修改完對所有的客戶端都生效,有時單個客戶端需要有特定的系統(tǒng)變量,顯然不符合要求。

所以這里介紹第三種方式,采用set的形式修改系統(tǒng)變量。

Set的形式修改系統(tǒng)變量

在Mysql客戶端我們可以采用Set命令直接修改系統(tǒng)變量,不過需要注意的是,Set的形式修改會指定系統(tǒng)變量生效的范圍,因為當多個客戶端連接同一個服務端時可能一個系統(tǒng)變量需要作用于所有的客戶端,有的系統(tǒng)變量只需要作用于當前的客戶端即可,根據作用范圍分為如下兩種。

  • **GLOBAL:**針對所有的客戶端生效。
  • **SESSION(也被稱為local):**只對當前會話生效,其余客戶端不受影響。

顯然對于my.cnf設置配置和啟動項配置都是作用于所有的客戶端,也就是GLOBAL作用范圍,那么只針對當前客戶端的系統(tǒng)變量需要如何設置呢,

體驗如下所示:

#### 先查詢一次存儲引擎的值
mysql> show variables like '%default_storage_engine%';
+------------------------+--------+
| Variable_name          | Value  |
+------------------------+--------+
| default_storage_engine | MyISAM |
+------------------------+--------+
1 row in set (0.00 sec)

mysql> set default_storage_engine=InnoDB;
Query OK, 0 rows affected (0.00 sec)

mysql> show variables like '%default_storage_engine%';
+------------------------+--------+
| Variable_name          | Value  |
+------------------------+--------+
| default_storage_engine | InnoDB |
+------------------------+--------+
1 row in set (0.00 sec)

SESSION作用范圍語法

我們在使用set命令改變系統(tǒng)變量的值其實默認就是session范圍的語法,具體語法如下:

### 語法一:默認采用session
mysql> set default_storage_engine=InnoDB;
### 語法二:指定作用范圍session
mysql> set session default_storage_engine InnoDB;
### 語法三
mysql> set @@session.default_storage_engine=InnoDB;

GLOBAL作用范圍語法

global影響范圍是所有的客戶端,具體語法如下所示:

### 語法一
mysql> set global default_storage_engine=InnoDB;
### 語法二
mysql> set @@global.default_storage_engine=MyISAM;

查看系統(tǒng)變量值

從上面我們知道了Mysql中的系統(tǒng)變量分為兩種操作范圍,同樣查詢系統(tǒng)變量時也是分作用范圍查詢,查詢系統(tǒng)變量語法如下所示。

show [global|session]  variables like [匹配元素支持模糊匹配%]

默認顯示的是session作用范圍的系統(tǒng)變量。

命令演示如下:

### 查詢session當前客戶端存儲引擎的系統(tǒng)變量
mysql> show session variables like 'default_storage_engine';
+------------------------+--------+
| Variable_name          | Value  |
+------------------------+--------+
| default_storage_engine | InnoDB |
+------------------------+--------+
1 row in set (0.01 sec)
### 查詢global所有客戶端存儲引擎的系統(tǒng)變量
mysql> show global  variables like 'default_storage_engine';
+------------------------+--------+
| Variable_name          | Value  |
+------------------------+--------+
| default_storage_engine | InnoDB |
+------------------------+--------+
1 row in set (0.01 sec)

### 改變全局系統(tǒng)變量【默認存儲引擎】
mysql> set global default_storage_engine=MyISAM;
Query OK, 0 rows affected (0.00 sec)

### 再次查詢全局系統(tǒng)變量【默認存儲引擎】值,修改成功?。。。。。?!
mysql> show global  variables like 'default_storage_engine';
+------------------------+--------+
| Variable_name          | Value  |
+------------------------+--------+
| default_storage_engine | MyISAM |
+------------------------+--------+
1 row in set (0.00 sec)

### 再次查詢當前客戶端【默認存儲引擎】值,沒有被修改??!
mysql> show session variables like 'default_storage_engine';
+------------------------+--------+
| Variable_name          | Value  |
+------------------------+--------+
| default_storage_engine | InnoDB |
+------------------------+--------+
1 row in set (0.00 sec)

注意:當修改全局global作用范圍的系統(tǒng)變量時,session作用范圍的相同名字系統(tǒng)變量值并不會馬上修改,需要等客戶端下一次接入時才會生效,也就是說修改全局global作用范圍的系統(tǒng)變量,只會影響后續(xù)接入客戶端作用范圍為session的系統(tǒng)變量。

系統(tǒng)變量注意點

并不是所有的系統(tǒng)變量都有session范圍和global范圍

只有session范圍的系統(tǒng)變量

只有session范圍的系統(tǒng)變量,如insert_id,表示對當前客戶端表設置了自增長AUTO_INCREMENT列,插入數據的自增長id初始值,

演示如下:

### 初始值默認0
mysql> show variables like 'insert_id';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| insert_id     | 0     |
+---------------+-------+
1 row in set (0.00 sec)
### 設置初始值為2
mysql> set session insert_id=2;
Query OK, 0 rows affected (0.00 sec)

### 創(chuàng)建一張表,帶有自增長AUTO_INCREMENT列
mysql> CREATE TABLE tb_student(
    -> id INT(4) PRIMARY KEY AUTO_INCREMENT,
    -> name VARCHAR(25) NOT NULL
    -> );
Query OK, 0 rows affected (0.00 sec)

mysql> insert into tb_student(name) values('zhangsan');
Query OK, 1 row affected (0.00 sec)

### 自增長初始值由0變?yōu)?,設置成功??!
mysql> select * from tb_student;
+----+----------+
| id | name     |
+----+----------+
|  2 | zhangsan |
+----+----------+
1 row in set (0.00 sec)

session作用范圍的不能設置為全局系統(tǒng)變量,提示如下:

mysql> set global insert_id=2;
ERROR 1228 (HY000): Variable 'insert_id' is a SESSION variable and can't be used with SET GLOBAL

只有global范圍的系統(tǒng)變量

這類變量多為系統(tǒng)功能支持變量,如max_connections系統(tǒng)最大連接數,只能采用global修改

mysql> set max_connections=123;
ERROR 1229 (HY000): Variable 'max_connections' is a GLOBAL variable and should be set with SET GLOBAL

并不是所有系統(tǒng)變量可以修改

對于絕大多數系統(tǒng)變量來講都是可以修改的,但萬事有例外,有些系統(tǒng)變量只讀,如version查看數據庫版本。

mysql> show variables like 'version';
+---------------+--------+
| Variable_name | Value  |
+---------------+--------+
| version       | 5.7.26 |
+---------------+--------+
1 row in set (0.01 sec)

### 只讀系統(tǒng)變量修改報錯
mysql> set version='1.0.0';
ERROR 1238 (HY000): Variable 'version' is a read only variable

狀態(tài)變量

系統(tǒng)變量是能夠影響程序的運行行為的變量,而狀態(tài)變量是能夠幫我們了解程序運行過程中的情況,這些狀態(tài)變量的值由程序運行過程中產生,不可設置,具體語法如下

show [global|session] status like  [匹配元素支持模糊匹配%]

不寫明作用范圍默認session

命令演示如下:

### 默認查詢session作用范圍的數據
mysql> show status like '%threads%';
+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+
| Delayed_insert_threads | 0     |
| Slow_launch_threads    | 0     |
| Threads_cached         | 0     |
| Threads_connected      | 2     |
| Threads_created        | 2     |
| Threads_running        | 1     |
+------------------------+-------+

到此這篇關于Mysql系統(tǒng)變量與狀態(tài)變量詳細介紹的文章就介紹到這了,更多相關Mysql系統(tǒng)變量內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • mysql 5.6.21 安裝與配置詳細步驟

    mysql 5.6.21 安裝與配置詳細步驟

    這篇文章主要介紹了mysql5.6.21安裝與配置的詳細步驟,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • MySQL性能指標TPS+QPS+IOPS壓測

    MySQL性能指標TPS+QPS+IOPS壓測

    這篇文章主要介紹了MySQL性能指標TPS+QPS+IOPS壓測,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-08-08
  • MySQL中的唯一索引的簡單學習教程

    MySQL中的唯一索引的簡單學習教程

    這篇文章主要介紹了MySQL中的唯一索引的簡單學習教程,是MySQL入門學習中的基礎知識,需要的朋友可以參考下
    2015-11-11
  • MySQL數據庫服務器端核心參數詳解和推薦配置

    MySQL數據庫服務器端核心參數詳解和推薦配置

    MySQL手冊上也有服務器端參數的解釋,以及參數值的相關說明信息,現(xiàn)針對我們大家重點需要注意、需要修改或影響性能 的服務器端參數,作其用處的解釋和如何配置參數值的推薦,此事情拖了不少時間,為方便大家?guī)兔m錯
    2011-12-12
  • 深入分析MySQL數據類型 DECIMAL

    深入分析MySQL數據類型 DECIMAL

    這篇文章主要介紹了MySQL數據類型 DECIMAL的相關資料,幫助大家更好的理解和使用MySQL數據庫,感興趣的朋友可以了解下
    2020-09-09
  • 總結MySQL建表、查詢優(yōu)化的一些實用小技巧

    總結MySQL建表、查詢優(yōu)化的一些實用小技巧

    本篇文章是對MySQL建表以及查詢優(yōu)化的一些實用小技巧進行了詳細的分析介紹,需要的朋友參考下
    2013-07-07
  • 詳解windows下mysql的主從同步

    詳解windows下mysql的主從同步

    本文主要對windows下的mysql主從同步進行詳細介紹。具有很好的參考價值,需要的朋友一起來看下吧
    2016-12-12
  • mysql 報錯 incompatible with sql_mode=only_full_group_by解決

    mysql 報錯 incompatible with sql_mode=only

    這篇文章主要為大家介紹了mysql 報錯 incompatible with sql_mode=only_full_group_by解決方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • MySQL數據庫的多種連接方式以及實用工具

    MySQL數據庫的多種連接方式以及實用工具

    mysql連接操作是客戶端進程與mysql數據庫實例進程進行通信,下面這篇文章主要給大家介紹了關于MySQL數據庫的多種連接方式以及實用工具的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • Java的Struts框架中的主題模板和國際化設置

    Java的Struts框架中的主題模板和國際化設置

    這篇文章主要介紹了Java的Struts框架中的主題模板和國際化設置,Struts是Java的SSH三大web開放框架之一,需要的朋友可以參考下
    2015-12-12

最新評論