https://www.cnblogs.com/SQL888/p/5750161.html膘叔
https://www.cnblogs.com/saneri/p/6963583.html
MySQL中show语法
1. show tables或show tables from database_name; -- 显示当前数据库中所有表的名称。
2. show databases; -- 显示mysql中所有数据库的名称。
3. show columns from table_name from database_name; 或show columns from database_name.table_name; -- 显示表中列名称。
4. show grants for user_name; -- 显示一个用户的权限,显示结果类似于grant 命令。
5. show index from table_name; -- 显示表的索引。
6. show status; -- 显示一些系统特定资源的信息,例如,正在运行的线程数量。
7. show variables; -- 显示系统变量的名称和值。
8. show processlist; -- 显示系统中正在运行的所有进程,也就是当前正在执行的查询。大多数用户可以查看他们自己的进程,但是如果他们拥有process权限,就可以查看所有人的进程,包括密码。
9. show table status; -- 显示当前使用或者指定的database中的每个表的信息。信息包括表类型和表的最新更新时间。
10. show privileges; -- 显示服务器所支持的不同权限。
11. show create database database_name; -- 显示create database 语句是否能够创建指定的数据库。
12. show create table table_name; -- 显示create database 语句是否能够创建指定的数据库。
13. show engines; -- 显示安装以后可用的存储引擎和默认引擎。
14. show innodb status; -- 显示innoDB存储引擎的状态。
15. show logs; -- 显示BDB存储引擎的日志。
16. show warnings; -- 显示最后一个执行的语句所产生的错误、警告和通知。
17. show errors; -- 只显示最后一个执行语句所产生的错误。
18. show [storage] engines; --显示安装后的可用存储引擎和默认引擎。
mysql show命令
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 |
+---------------------------------------------------------------------+
1
MySQL中 show 语法的使用:
1
2
3
4
5
6
7
|
mysql>
select
version();
+------------+
| version() |
+------------+
| 5.6.16-log |
+------------+
1 row
in
set
(0.00 sec)
|
帮助查看:
1
2
3
|
mysql> help show
mysql> help SHOW TABLE;
mysql> help SHOW WARNINGS
|
1.显示mysql中所有数据库的名称.
1
|
mysql>show databases;
|
2.显示当前数据库中所有表的名称
1
2
3
|
mysql>show tables;
或
mysql>show tables
from
database_name;
|
3.显示表中列名称
1
|
mysql>show columns
from
database_name.table_name;
|
4.查看某MySQL用户的使用权限
1
|
mysql>show grants
for
user_name;
|
5.显示create database 语句是否能够创建指定的数据库,并可以查看到创建库语句的SQL信息。
1
|
mysql>show create database database_name;
|
6.显示create table 语句是否能够创建指定的数据表,并可以查看到表创建语句的SQL信息。
1
|
mysql>show create table table_name;
|
7.显示安装以后可用的存储引擎和默认引擎。
1
|
mysql>show engines;
|
8.显示最后一个执行的语句所产生的错误、警告和通知
1
|
mysql> show warnings;
|
9.只显示最后一个执行语句所产生的错误
1
|
mysql>show errors;
|
10.显示系统中正在运行的所有进程,也就是当前正在执行的查询.
1
|
mysql> show processlist\G
|
11.查看所有存储过程。
1
|
mysql> show procedure status;
|
12.查看某个存储过程内容
1
|
show create procedure 存储过程名称;
|
13.查看函数的内容.
1
|
show create function func_name;
|
......
由于这几个show指令的参数太多,这里单独进行解析.
使用 show status 查看MySQL服务器状态信息.
有些时候我们需要了解MySQL的服务器状态信息,譬如当前MySQL启动后的运行时间,当前MySQL的客户端会话连接数,当前MySQL服务器执行的慢查询数,当前MySQL执行了多少SELECT
语句、执行了多少UPDATE
/DELETE
/INSERT
语句等统计信息,从而便于我们根据当前MySQL服务器的运行状态进行对应的调整或优化工作。
在MySQL中,我们可以使用SHOW STATUS
指令语句来查看MySQL服务器的状态信息。下面,我们以DOS命令窗口的形式连接MySQL,并执行show status;
指令,我们将看到如下显示信息:
1
2
3
4
5
6
7
8
9
10
11
|
---执行show status指令显示的部分结果---
+-----------------------------------------------------------------+--------------------------+
| Variable_name | Value |
+-----------------------------------------------------------------+--------------------------+
| Aborted_clients | 737
| Tokudb_FILESYSTEM_PREAD_NUM | 16 |
| Tokudb_FILESYSTEM_PREAD_BYTES | 8192 |
| Tokudb_FILESYSTEM_LONG_PREAD_TIME | 0 |
| Tokudb_FILESYSTEM_LONG_PREAD_NUM | 0 |
| Uptime | 2697503 |
| Uptime_since_flush_status | 2697503
|
当我们执行show status语句时,MySQL将会列出多达300多条的状态信息记录,其中包括了供我们查看了解的各种信息。不过,如果直接使用show status指令得到300多条记录,会让我们看得眼花缭乱,因此我们希望能够按需查看一部分状态信息。这个时候,我们可以在show status语句后加上对应的like子句。
例如:
--查询当前MySQL本次启动后的运行统计时间.
1
2
3
4
5
6
7
|
mysql> show status like
'uptime'
;
+---------------+---------+
| Variable_name | Value |
+---------------+---------+
| Uptime | 2698122 |
+---------------+---------+
1 row
in
set
(0.00 sec)
|
--查询本次MySQL启动后执行的SELECT语句的次数.
1
2
3
4
5
6
7
|
mysql> show status like
'com_select'
;
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Com_select | 2 |
+---------------+-------+
1 row
in
set
(0.00 sec)
|
此外,与WHERE子句中的LIKE关键字类似,show status后的LIKE关键字也可以使用'_' 或'%'等通配符来进行模糊匹配。例如我们可以执行如下语句来查看MySQL服务器的线程信息:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
mysql> show status like
'Thread_%'
;
+-------------------------+-------+
| Variable_name | Value |
+-------------------------+-------+
| Threadpool_idle_threads | 0 |
| Threadpool_threads | 0 |
| Threads_cached | 11 |
| Threads_connected | 1 |
| Threads_created | 15 |
| Threads_rejected | 0 |
| Threads_running | 3 |
+-------------------------+-------+
7 rows
in
set
(0.00 sec)
|
值得注意的是,在上述show status like 'com_select'指令的执行示例中,显示的SELECT语句统计信息仅仅表示当前会话连接执行的SELECT语句数量。因为,show status指令的完整语法如下:
1
2
|
SHOW [统计范围] STATUS [LIKE
'状态项名称'
]
--统计范围关键字分为GLOBAL和SESSION(或LOCAL)两种。
|
在show status的完整语法中,"[]"中的部分是可选的,如果我们的show status语句中不包含统计范围关键字,则默认统计范围为SESSION,也就是只统计当前连接的状态信息。如果我们需要查询自当前MySQL启动后所有连接执行的SELECT语句总数,我们可以执行如下语句:
1
|
mysql> show global status like
'com_select'
;
|
以上即是show status的详细用法。由于show status的状态统计项较多,我们就不再一一解释每个统计项的具体含义,在这里,我们仅列出部分常用的状态信息查看语句:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
--查看MySQL本次启动后的运行时间(单位:秒)
show status like
'uptime'
;
--查看
select
语句的执行数
show [global] status like
'com_select'
;
--查看insert语句的执行数
show [global] status like
'com_insert'
;
--查看update语句的执行数
show [global] status like
'com_update'
;
--查看delete语句的执行数
show [global] status like
'com_delete'
;
--查看试图连接到MySQL(不管是否连接成功)的连接数
show status like
'connections'
;
--查看线程缓存内的线程的数量。
show status like
'threads_cached'
;
--查看当前打开的连接的数量。
show status like
'threads_connected'
;
--查看当前打开的连接的数量。
show status like
'threads_connected'
;
--查看创建用来处理连接的线程数。如果Threads_created较大,你可能要增加thread_cache_size值。
show status like
'threads_created'
;
--查看激活的(非睡眠状态)线程数。
show status like
'threads_running'
;
--查看立即获得的表的锁的次数。
show status like
'table_locks_immediate'
;
--查看不能立即获得的表的锁的次数。如果该值较高,并且有性能问题,你应首先优化查询,然后拆分表或使用复制。
show status like
'table_locks_waited'
;
--查看创建时间超过slow_launch_time秒的线程数。
show status like
'slow_launch_threads'
;
--查看查询时间超过long_query_time秒的查询的个数。
show status like
'slow_queries'
;
|
使用 SHOW INDEX 语法 查看表的索引状态
语法:
1
|
SHOW INDEX FROM [tb_name]
|
执行后结果如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
mysql> SHOW INDEX FROM l_yy\G
*************************** 1. row ***************************
Table: l_yy
Non_unique: 0
Key_name: PRIMARY
Seq_in_index: 1
Column_name: id
Collation: A
Cardinality: 8556
Sub_part: NULL
Packed: NULL
Null:
Index_type: BTREE
Comment:
Index_comment:
1 row
in
set
(0.00 sec)
|
show index 返回字段解析:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
· Table
表的名称。
· Non_unique
如果索引不能包括重复词,则为0。如果可以,则为1。
· Key_name
索引的名称。
· Seq_in_index
索引中的列序列号,从1开始。
· Column_name
列名称。
· Collation
列以什么方式存储在索引中。在MySQL中,有值‘A’(升序)或NULL(无分类).
· Cardinality
索引中唯一值的数目的估计值。通过运行ANALYZE TABLE或myisamchk -a可以更新.
· Sub_part
如果列只是被部分地编入索引,则为被编入索引的字符的数目。如果整列被编入索引,则为NULL。
· Packed
指示关键字如何被压缩。如果没有被压缩,则为NULL。
· Null
如果列含有NULL,则含有YES。如果没有,则该列含有NO。
· Index_type
用过的索引方法(BTREE, FULLTEXT, HASH, RTREE)。
· Comment
多种评注。
|
show variables用于显示mysql服务器变量。
mysqld服务维护两种变量。全局变量影响服务器的全局操作。会话变量影响具体客户端连接相关操作。
通过连接服务器并执行SET GLOBAL var_name语句可以更改动态全局变量。要想更改全局变量,必须具有SUPER权限,重启mysql服务后失效.
通过SET SESSION var_name语句来更改动态会话变量.但客户可以只更改自己的会话变量,而不更改其它客户的会话变量,退出终端后更改失效.
SHOW VARIABLES通常结合like使用,具体用法如下:
1.查看全局字符集
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
mysql> show global variables like
'character%'
;
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | latin1 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows
in
set
(0.00 sec)
mysql> SHOW VARIABLES LIKE
'collation_%'
;
+----------------------+-------------------+
| Variable_name | Value |
+----------------------+-------------------+
| collation_connection | utf8_general_ci |
| collation_database | latin1_swedish_ci |
| collation_server | latin1_swedish_ci |
+----------------------+-------------------+
3 rows
in
set
(0.00 sec)
|
1
2
3
4
5
6
7
8
|
mysql> show global variables like
'%log_err%'
;
+---------------------+---------------------------------+
| Variable_name | Value |
+---------------------+---------------------------------+
| binlog_error_action | IGNORE_ERROR |
| log_error | /usr/local/mysql/logs/error.log |
+---------------------+---------------------------------+
2 rows
in
set
(0.00 sec)
|
3.查看二进制日志是否开启.
1
2
3
4
5
6
7
|
mysql> show variables like
'log_bin'
;
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| log_bin | OFF |
+---------------+-------+
1 row
in
set
(0.00 sec)
|
4.查看mysql的连接数.
1
2
3
4
5
6
7
8
|
mysql> show variables like
'%connections%'
;
+----------------------+-------+
| Variable_name | Value |
+----------------------+-------+
| max_connections | 151 |
| max_user_connections | 0 |
+----------------------+-------+
2 rows
in
set
(0.00 sec)
|
1
2
3
4
5
6
7
|
mysql> show variables like
'binlog_format'
;
+---------------+-----------+
| Variable_name | Value |
+---------------+-----------+
| binlog_format | STATEMENT |
+---------------+-----------+
1 row
in
set
(0.00 sec)
|
本处以更改日志格式的操作来说明set变量的使用
1
2
|
set
global binlog_format=mixed;
//全局更改,数据库重启后失效
set
session binlog_format=mixed;
//客户端更改,退出终端后失效.
|
更多使用以后慢慢整理和添加
参考文档:http://www.365mini.com/page/mysql-show-status.htm
http://www.ttlsa.com/mysql/mysql_show_status_descriptsions/
http://blog.oldboyedu.com/mysql-optimization/
http://baike.xsoftlab.net/view/218.html