91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL 參數相關概念及查詢更改方法

發布時間:2020-09-29 12:04:58 來源:腳本之家 閱讀:132 作者:MySQL技術 欄目:開發技術

前言:

在前面一些文章中,經常能看到介紹某某參數的作用,可能有些小伙伴仍搞不清楚 MySQL 參數是啥。本篇文章我們來聊聊 MySQL 參數,學習下如何管理維護 MySQL 參數。

1.MySQL參數概念

我們所說的參數在官方文檔中稱為 系統變量 (system variable),不同的變量有著不同的作用。 MySQL 服務端維護了許多表示其配置的系統變量,所有變量均有默認值。一般可以在啟動命令行中或配置文件中對它們進行設置。

系統變量分為全局系統變量(global)和會話系統變量(session)。有些變量既有全局變量又有會話變量,有些變量只有全局變量。全局變量影響服務器的全局操作,會話變量只影響具體客戶端連接相關操作。若會話變量未單獨設置,則繼承自相應全局變量。

MySQL 服務啟動時,會按照配置文件或命令行中指定的選項來給全局變量賦值,沒有指定則按默認值處理。服務啟動后,通過連接服務器并執行 SET GLOBAL var_name 語句可以動態更改部分全局變量的值。要想更改全局變量,必須具有 SUPER 權限。 MySQL 還為每個客戶端連接維護會話變量,連接時使用相應全局變量的當前值對客戶端會話變量進行初始化。客戶端可以通過 SET SESSION var_name 語句來動態更改會話變量。設置會話變量不需要特殊權限,但會話變量只作用于當前連接。

2.參數查詢與變更示例

這里也要說明下,并不是所有的參數都可以動態修改,某些參數只能寫入配置文件然后重啟數據庫才能生效。下面我們來展示下 MySQL 參數的查詢與修改。

# 參數查詢
show global variables like 'var_name'; //查看全局系統變量的值,可使用%通配符
show session variables like 'var_name'; //查看會話系統變量的值
show     variables like 'var_name'; //優先返回會話系統變量,若會話系統變量不存在,則返回全局系統變量。

# 也可用select查詢某個特定參數
select @@global.var_name; //全局系統變量
select @@session.var_name; //會話系統變量
select @@var_name; //優先會話系統變量

# 查詢示例
mysql> show global variables like 'server_id';
+---------------+---------+
| Variable_name | Value  |
+---------------+---------+
| server_id   | 1003306 |
+---------------+---------+
1 row in set (0.00 sec)

mysql> show global variables like 'log_bin%';
+---------------------------------+-------------------------------+
| Variable_name          | Value             |
+---------------------------------+-------------------------------+
| log_bin             | ON              |
| log_bin_basename        | /data/mysql/logs/binlog    |
| log_bin_index          | /data/mysql/logs/binlog.index |
| log_bin_trust_function_creators | ON              |
| log_bin_use_v1_row_events    | OFF              |
+---------------------------------+-------------------------------+
5 rows in set (0.00 sec)

mysql> select @@server_id;
+-------------+
| @@server_id |
+-------------+
|   1003306 |
+-------------+
1 row in set (0.00 sec)

# 動態修改參數
set global var_name = value;
set session var_name = value;
set var_name = value;

set @@global.var_name = value;
set @@session.var_name = value;
set @@var_name = value;

# 參數修改示例
mysql> set global sort_buffer_size = 2097152;
Query OK, 0 rows affected (0.00 sec)

mysql> set session sort_buffer_size = 4194304;
Query OK, 0 rows affected (0.00 sec)

mysql> select @@global.sort_buffer_size,@@session.sort_buffer_size;
+---------------------------+----------------------------+
| @@global.sort_buffer_size | @@session.sort_buffer_size |
+---------------------------+----------------------------+
|          2097152 |          4194304 |
+---------------------------+----------------------------+
1 row in set (0.00 sec)

參數動態修改后,建議將其寫入配置文件。因為動態修改的參數在 MySQL 服務重啟后會失效,只有寫入配置文件才能夠重啟后仍有效。對于一些無法動態修改的參數,我們只能通過修改配置文件,然后重啟來使之生效。這里所說的配置文件就是 my.cnf 文件了,Linux 系統一般在 /etc 目錄下;Windows 系統一般在 basedir 目錄下,名稱可命名為 my.ini 。大部分參數需要配置在 [mysqld] 下,一份簡單的配置文件示例如下:

vi /etc/my.cnf
# 簡單模板如下:
[mysqld]
user = mysql    
datadir = /data/mysql/data        
socket = /data/mysql/tmp/mysql.sock
pid-file = /data/mysql/tmp/mysqld.pid  
skip_name_resolve = 1
max_connections = 2000
lower_case_table_names = 1
log_timestamps=SYSTEM
max_allowed_packet = 32M
...

MySQL 參數一般由 DBA 或運維來維護,可能有些同學對這些參數還比較陌生。建議在數據庫初始化時,根據服務器規格設置對應的數據庫參數。對于不清楚作用的參數,建議保持默認值即可。關于更多參數相關的內容,可以參考官方文檔:

https://dev.mysql.com/doc/refman/5.7/en/server-system-variable-reference.html

總結:

本篇文章詳細講述了 MySQL 參數相關概念及查詢更改方法,希望各位小伙伴能學到相關知識。

以上就是MySQL 參數相關概念及查詢更改方法的詳細內容,更多關于MySQL 參數的資料請關注億速云其它相關文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

商南县| 日喀则市| 韶关市| 且末县| 澜沧| 天全县| 博白县| 赞皇县| 绥芬河市| 大同县| 南宁市| 和顺县| 屯昌县| 叙永县| 新昌县| 乡城县| 甘德县| 南靖县| 古浪县| 南丰县| 吉木乃县| 固阳县| 建平县| 太保市| 措勤县| 宁安市| 沁阳市| 饶平县| 泾川县| 阆中市| 犍为县| 张家界市| 江陵县| 信阳市| 多伦县| 湟中县| 九江县| 湖北省| 山西省| 永新县| 顺义区|