show databases;
show tables from db_name;
show columns from table_name from db_name;
show index from talbe_name [from db_name];
show status;
show variables;
show [full] processlist;
show table status [from db_name];
show grants for user;
除了status,processlist和grants外,其它的都可以帶有like wild選項,它可以使用SQL的'%'和'_'字元;
show databases like '%t';
將會列出所有資料庫名字末尾為't'字元的資料庫
當然了,在這些sql中,你也可以用db_name.table_name來代替 table_name from db_name這樣寫會更簡便些!
如果一個使用者沒有一個表的任何許可權,表將不在SHOW TABLES
或mysqlshow db_name
中的輸出中顯示
大家可能還記得describe table_name ,它實現的是與show columns from db_name.table_name一樣的效果
show status將可以用mysqlshow --status 來得到同樣的效果
列 |
含義 |
Name |
表名 |
Type |
表的類型 (ISAM,MyISAM或HEAP) |
Row_format |
行儲存格式 (固定, 動態, 或壓縮) |
Rows |
行數量 |
Avg_row_length |
平均行長度 |
Data_length |
資料檔案的長度 |
Max_data_length |
資料檔案的最大長度 |
Index_length |
索引檔案的長度 |
Data_free |
已指派但未使用了位元組數 |
Auto_increment |
下一個 autoincrement(自動加1)值 |
Create_time |
表被創造的時間 |
Update_time |
資料檔案最後更新的時間 |
Check_time |
最後對錶運行一個檢查的時間 |
Create_options |
與CREATE TABLE 一起使用的額外選項 |
Comment |
當創造表時,使用的注釋 (或為什麼MySQL不能存取表資訊的一些資訊)。 |
SHOW FIELDS
是SHOW COLUMNS
一個同義字,SHOW KEYS
是SHOW INDEX
一個同義字。你也可以用mysqlshow db_name tbl_name
或mysqlshow -k db_name tbl_name
列出一張表的列或索引。
SHOW INDEX
以非常相似於ODBC的SQLStatistics
調用的格式返回索引資訊。下面的列被返回:
列 |
含義 |
Table |
表名 |
Non_unique |
0,如果索引不能包含重複。 |
Key_name |
索引名 |
Seq_in_index |
索引中的列順序號, 從 1 開始。 |
Column_name |
列名。 |
Collation |
列怎樣在索引中被排序。在MySQL中,這可以有值A (升序) 或NULL (不排序)。 |
Cardinality |
索引中唯一值的數量。這可通過運行isamchk -a 更改. |
Sub_part |
如果列只是部分被索引,索引字元的數量。NULL ,如果整個鍵被索引。 |
SHOW STATUS
提供伺服器的狀態資訊(象mysqladmin extended-status
一樣)。輸出類似於下面的顯示,儘管格式和數字可以有點不同:
+--------------------------+--------+
| Variable_name | Value |
+--------------------------+--------+
| Aborted_clients | 0 |
| Aborted_connects | 0 |
| Connections | 17 |
| Created_tmp_tables | 0 |
| Delayed_insert_threads | 0 |
| Delayed_writes | 0 |
| Delayed_errors | 0 |
| Flush_commands | 2 |
| Handler_delete | 2 |
| Handler_read_first | 0 |
| Handler_read_key | 1 |
| Handler_read_next | 0 |
| Handler_read_rnd | 35 |
| Handler_update | 0 |
| Handler_write | 2 |
| Key_blocks_used | 0 |
| Key_read_requests | 0 |
| Key_reads | 0 |
| Key_write_requests | 0 |
| Key_writes | 0 |
| Max_used_connections | 1 |
| Not_flushed_key_blocks | 0 |
| Not_flushed_delayed_rows | 0 |
| Open_tables | 1 |
| Open_files | 2 |
| Open_streams | 0 |
| Opened_tables | 11 |
| Questions | 14 |
| Slow_queries | 0 |
| Threads_connected | 1 |
| Threads_running | 1 |
| Uptime | 149111 |
+--------------------------+--------+
上面列出的狀態變數有下列含義:
Aborted_clients |
由於客戶沒有正確關閉串連已經死掉,已經放棄的串連數量。 |
Aborted_connects |
嘗試已經失敗的MySQL伺服器的串連的次數。 |
Connections |
試圖串連MySQL伺服器的次數。 |
Created_tmp_tables |
當執行語句時,已經被創造了的隱含暫存資料表的數量。 |
Delayed_insert_threads |
正在使用的延遲插入處理器線程的數量。 |
Delayed_writes |
用INSERT DELAYED 寫入的行數。 |
Delayed_errors |
用INSERT DELAYED 寫入的發生某些錯誤(可能重複索引值 )的行數。 |
Flush_commands |
執行FLUSH 命令的次數。 |
Handler_delete |
請求從一張表中刪除行的次數。 |
Handler_read_first |
請求讀入表中第一行的次數。 |
Handler_read_key |
請求數字基於鍵讀行。 |
Handler_read_next |
請求讀入基於一個鍵的一行的次數。 |
Handler_read_rnd |
請求讀入基於一個固定位置的一行的次數。 |
Handler_update |
請求更新表中一行的次數。 |
Handler_write |
請求向表中插入一行的次數。 |
Key_blocks_used |
用於關鍵字緩衝的塊的數量。 |
Key_read_requests |
請求從緩衝讀入一個索引值的次數。 |
Key_reads |
從磁碟物理讀入一個索引值的次數。 |
Key_write_requests |
請求將一個關鍵字塊寫入緩衝次數。 |
Key_writes |
將一個索引值塊物理寫入磁碟的次數。 |
Max_used_connections |
同時使用的串連的最大數目。 |
Not_flushed_key_blocks |
在金鑰快取中已經改變但是還沒被清空到磁碟上的鍵塊。 |
Not_flushed_delayed_rows |
在INSERT DELAY 隊列中等待寫入的行的數量。 |
Open_tables |
開啟表的數量。 |
Open_files |
開啟檔案的數量。 |
Open_streams |
開啟流的數量(主要用於日誌記載) |
Opened_tables |
已經開啟的表的數量。 |
Questions |
發往伺服器的查詢的數量。 |
Slow_queries |
要花超過long_query_time 時間的查詢數量。 |
Threads_connected |
當前開啟的串連的數量。 |
Threads_running |
不在睡眠的線程數量。 |
Uptime |
伺服器工作了多少秒。 |
關於上面的一些注釋:
- 如果
Opened_tables
太大,那麼你的table_cache
變數可能太小。
- 如果
key_reads
太大,那麼你的key_cache
可能太小。快取命中率可以用key_reads
/key_read_requests
計算。
- 如果
Handler_read_rnd
太大,那麼你很可能有大量的查詢需要MySQL掃描整個表或你有沒正確使用索引值的連接(join)。
SHOW VARIABLES
顯示出一些MySQL系統變數的值,你也能使用mysqladmin variables
命令得到這個資訊。如果預設值不合適,你能在mysqld
啟動時使用命令列選項來設定這些變數的大多數。輸出類似於下面的顯示,儘管格式和數字可以有點不同:
+------------------------+--------------------------+
| Variable_name | Value |
+------------------------+--------------------------+
| back_log | 5 |
| connect_timeout | 5 |
| basedir | /my/monty/ |
| datadir | /my/monty/data/ |
| delayed_insert_limit | 100 |
| delayed_insert_timeout | 300 |
| delayed_queue_size | 1000 |
| join_buffer_size | 131072 |
| flush_time | 0 |
| interactive_timeout | 28800 |
| key_buffer_size | 1048540 |
| language | /my/monty/share/english/ |
| log | OFF |
| log_update | OFF |
| long_query_time | 10 |
| low_priority_updates | OFF |
| max_allowed_packet | 1048576 |
| max_connections | 100 |
| max_connect_errors | 10 |
| max_delayed_threads | 20 |
| max_heap_table_size | 16777216 |
| max_join_size | 4294967295 |
| max_sort_length | 1024 |
| max_tmp_tables | 32 |
| net_buffer_length | 16384 |
| port | 3306 |
| protocol-version | 10 |
| record_buffer | 131072 |
| skip_locking | ON |
| socket | /tmp/mysql.sock |
| sort_buffer | 2097116 |
| table_cache | 64 |
| thread_stack | 131072 |
| tmp_table_size | 1048576 |
| tmpdir | /machine/tmp/ |
| version | 3.23.0-alpha-debug |
| wait_timeout | 28800 |
+------------------------+--------------------------+SHOW PROCESSLIST
顯示哪個線程正在運行,你也能使用mysqladmin processlist
命令得到這個資訊。
如果你有process許可權, 你能看見所有的線程,否則,你僅能看見你自己的線程。
見7.20 KILL
句法。如果你不使用FULL
選項,那麼每個查詢只有頭100字元被顯示出來。
SHOW GRANTS FOR user
列出對一個使用者必鬚髮出以重複授權的授權命令。
mysql> SHOW GRANTS FOR root@localhost;
+---------------------------------------------------------------------+
| Grants for root@localhost |
+---------------------------------------------------------------------+
| GRANT ALL PRIVILEGES ON *.* TO 'root''localhost' WITH GRANT OPTION |
+---------------------------------------------------------------------+