如何使用sql语句mysql查看建索引语句mysql表上的索引信息

mysql中创建各种索引的语句整理_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
mysql中创建各种索引的语句整理
上传于||文档简介
&&m​y​s​q​l​中​创​建​各​种​索​引​的​语​句​整​理
阅读已结束,如果下载本文需要使用0下载券
想免费下载更多文档?
定制HR最喜欢的简历
你可能喜欢官方mysql中查看索引是否被使用到
官方mysql中查看索引是否被使用到:
在percona版本或marida中可以通过
information_schea.index_statistics查看得到,
在官方版本中如何查看呢?
object_type,object_schema,object_name,index_name,count_star,count_read,COUNT_FETCH
performance_schema.table_io_waits_summary_by_index_
应该可以通过上面的sql得到。 如果read,fetch的次数都为0的话,应该是没有被使用过的。
通过下面的例子,可以证实:
启动mysql:
mysql& show create table a.t3;
+-------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table & &
+-------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| t3 & &| CREATE TABLE `t3`
& `id` int(11) DEFAULT NULL,
& `name` varchar(10) NOT NULL DEFAULT 'bb',
& KEY `idx_t3` (`id`),
& KEY `idx_t3_name` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+-------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.01 sec)
mysql& select
object_type,object_schema,object_name,index_name,count_star,count_read,COUNT_FETCH
from performance_schema.table_io_waits_summary_by_index_usage where
object_name='t3';
+-------------+---------------+-------------+-------------+------------+------------+-------------+
| object_type | object_schema | object_name | index_name
&| count_star | count_read | COUNT_FETCH |
+-------------+---------------+-------------+-------------+------------+------------+-------------+
| TABLE & & & |
& & & | t3
& &| idx_t3 &
| TABLE & & & |
& & & | t3
& &| idx_t3_name |
| TABLE & & & |
& & & | t3
& &| NULL &
+-------------+---------------+-------------+-------------+------------+------------+-------------+
3 rows in set (0.01 sec)
mysql& explain select id from t3 where id=1;
ERROR ): No database selected
mysql& explain select id from a.t3 where id=1;
+----+-------------+-------+------+---------------+--------+---------+-------+------+-------------+
| id | select_type | table | type | possible_keys | key
& &| key_len | ref
& | rows | Extra &
+----+-------------+-------+------+---------------+--------+---------+-------+------+-------------+
| &1 | SIMPLE &
&| ref &| idx_t3
&| idx_t3 | 5 &
& & | const | &
&1 | Using index |
+----+-------------+-------+------+---------------+--------+---------+-------+------+-------------+
1 row in set (0.00 sec)
mysql& select
object_type,object_schema,object_name,index_name,count_star,count_read,COUNT_FETCH
from performance_schema.table_io_waits_summary_by_index_usage where
object_name='t3';
+-------------+---------------+-------------+-------------+------------+------------+-------------+
| object_type | object_schema | object_name | index_name
&| count_star | count_read | COUNT_FETCH |
+-------------+---------------+-------------+-------------+------------+------------+-------------+
| TABLE & & & |
& & & | t3
& &| idx_t3 &
| TABLE & & & |
& & & | t3
& &| idx_t3_name |
| TABLE & & & |
& & & | t3
& &| NULL &
+-------------+---------------+-------------+-------------+------------+------------+-------------+
3 rows in set (0.01 sec)
Reading table information for completion of table and column
You can turn off this feature to get a quicker startup with
Database changed
mysql& select id from t3 where id=1;
Empty set (0.00 sec)
mysql& select
object_type,object_schema,object_name,index_name,count_star,count_read,COUNT_FETCH
from performance_schema.table_io_waits_summary_by_index_usage where
object_name='t3';
+-------------+---------------+-------------+-------------+------------+------------+-------------+
| object_type | object_schema | object_name | index_name
&| count_star | count_read | COUNT_FETCH |
+-------------+---------------+-------------+-------------+------------+------------+-------------+
| TABLE & & & |
& & & | t3
& &| idx_t3 &
| TABLE & & & |
& & & | t3
& &| idx_t3_name |
| TABLE & & & |
& & & | t3
& &| NULL &
+-------------+---------------+-------------+-------------+------------+------------+-------------+
3 rows in set (0.00 sec)
mysql& select id from t3 where id=10; &
& +------+
2 rows in set (0.00 sec)
mysql& select
object_type,object_schema,object_name,index_name,count_star,count_read,COUNT_FETCH
from performance_schema.table_io_waits_summary_by_index_usage where
object_name='t3';
+-------------+---------------+-------------+-------------+------------+------------+-------------+
| object_type | object_schema | object_name | index_name
&| count_star | count_read | COUNT_FETCH |
+-------------+---------------+-------------+-------------+------------+------------+-------------+
| TABLE & & & |
& & & | t3
& &| idx_t3 &
| TABLE & & & |
& & & | t3
& &| idx_t3_name |
| TABLE & & & |
& & & | t3
& &| NULL &
+-------------+---------------+-------------+-------------+------------+------------+-------------+
3 rows in set (0.01 sec)
mysql& select name from t3 where name='a';
Empty set (0.00 sec)
mysql& select
object_type,object_schema,object_name,index_name,count_star,count_read,COUNT_FETCH
from performance_schema.table_io_waits_summary_by_index_usage where
object_name='t3';
+-------------+---------------+-------------+-------------+------------+------------+-------------+
| object_type | object_schema | object_name | index_name
&| count_star | count_read | COUNT_FETCH |
+-------------+---------------+-------------+-------------+------------+------------+-------------+
| TABLE & & & |
& & & | t3
& &| idx_t3 &
| TABLE & & & |
& & & | t3
& &| idx_t3_name |
| TABLE & & & |
& & & | t3
& &| NULL &
+-------------+---------------+-------------+-------------+------------+------------+-------------+
3 rows in set (0.01 sec)
mysql& select name from t3 where name='name1';
1 row in set (0.01 sec)
mysql& select
object_type,object_schema,object_name,index_name,count_star,count_read,COUNT_FETCH
from performance_schema.table_io_waits_summary_by_index_usage where
object_name='t3';
+-------------+---------------+-------------+-------------+------------+------------+-------------+
| object_type | object_schema | object_name | index_name
&| count_star | count_read | COUNT_FETCH |
+-------------+---------------+-------------+-------------+------------+------------+-------------+
| TABLE & & & |
& & & | t3
& &| idx_t3 &
| TABLE & & & |
& & & | t3
& &| idx_t3_name |
| TABLE & & & |
& & & | t3
& &| NULL &
+-------------+---------------+-------------+-------------+------------+------------+-------------+
3 rows in set (0.01 sec)
索引被使用之后, 对应的值会增加。&
转载请注明源出处
&欢迎一起学习
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。Mysql建表与索引使用规范详解
字体:[ ] 类型:转载 时间:
本篇文章是对Mysql建表和索引使用规范进行了详细的分析介绍,需要的朋友参考下
一、 MySQL建表,字段需设置为非空,需设置字段默认值。二、 MySQL建表,字段需NULL时,需设置字段默认值,默认值不为NULL。三、 MySQL建表,如果字段等价于外键,应在该字段加索引。四、 MySQL建表,不同表之间的相同属性值的字段,列类型,类型长度,是否非空,是否默认值,需保持一致,否则无法正确使用索引进行关联对比。五、 MySQL使用时,一条SQL语句只能使用一个表的一个索引。所有的字段类型都可以索引,多列索引的属性最多15个。六、 如果可以在多个索引中进行选择,MySQL通常使用找到最少行的索引,索引唯一值最高的索引。七、 建立索引index(part1,part2,part3),相当于建立了 index(part1),index(part1,part2)和index(part1,part2,part3)三个索引。八、 MySQL针对like语法必须如下格式才使用索引:&&&& SELECT * FROM t1 WHERE key_col LIKE 'ab%' ;九、 SELECT COUNT(*) 语法在没有where条件的语句中执行效率没有SELECT COUNT(col_name)快,但是在有where条件的语句中执行效率要快。十、 在where条件中多个and的条件中,必须都是一个多列索引的key_part属性而且必须包含key_part1。各自单一索引的话,只使用遍历最少行的那个索引。十一、 在where条件中多个or的条件中,每一个条件,都必须是一个有效索引。十二、 ORDER BY 后面的条件必须是同一索引的属性,排序顺序必须一致(比如都是升序或都是降序)。十三、 所有GROUP BY列引用同一索引的属性,并且索引必须是按顺序保存其关键字的。十四、 JOIN 索引,所有匹配ON和where的字段应建立合适的索引。十五、 对智能的扫描全表使用FORCE INDEX告知MySQL,使用索引效率更高。十六、 定期ANALYZE TABLE tbl_name为扫描的表更新关键字分布 。十七、 定期使用慢日志检查语句,执行explain,分析可能改进的索引。十八、 条件允许的话,设置较大的key_buffer_size和query_cache_size的值(全局参数),和sort_buffer_size的值(session变量,建议不要超过4M)。备注主键的命名采用如下规则:主键名用pk_开头,后面跟该主键所在的表名。主键名长度不能超过30个字符。如果过长,可对表名进行缩写。缩写规则同表名的缩写规则。主键名用小写的英文单词来表示。&外键的命名采用如下规则:外键名用fk_开头,后面跟该外键所在的表名和对应的主表名(不含t_)。子表名和父表名自己用下划线(_)分隔。外键名长度不能超过30个字符。如果过长,可对表名进行缩写。缩写规则同表名的缩写规则。外键名用小写的英文单词来表示。索引的命名采用如下规则:1)索引名用小写的英文字母和数字表示。索引名的长度不能超过30个字符。2)主键对应的索引和主键同名。3)唯一性索引用uni_开头,后面跟表名。一般性索引用ind_开头,后面跟表名。4)如果索引长度过长,可对表名进行缩写。缩写规则同表名的缩写规则index 相关语法例:CREATE INDEX log_url ON logaudit_log(url);show index from logaudit_logdrop index log_request_time on logaudit_log
sql执行效率检测 mysql explainexplain显示了mysql如何使用索引来处理select语句以及连接表。可以帮助选择更好的索引和写出更优化的查询语句。使用方法,在select语句前加上explain就可以了:如:explain select surname,first_name form a,b where a.id=b.id分析结果形式如下:table |& type | possible_keys | key | key_len& | ref | rows | ExtraEXPLAIN列的解释:table显示这一行的数据是关于哪张表的type这是重要的列,显示连接使用了何种类型。从最好到最差的连接类型为const、eq_reg、ref、range、indexhe和ALLpossible_keys显示可能应用在这张表中的索引。如果为空,没有可能的索引。可以为相关的域从WHERE语句中选择一个合适的语句key实际使用的索引。如果为NULL,则没有使用索引。很少的情况下,MYSQL会选择优化不足的索引。这种情况下,可以在SELECT语句中使用USEINDEX(indexname)来强制使用一个索引或者用IGNORE INDEX(indexname)来强制MYSQL忽略索引key_len使用的索引的长度。在不损失精确性的情况下,长度越短越好ref显示索引的哪一列被使用了,如果可能的话,是一个常数rowsMYSQL认为必须检查的用来返回请求数据的行数Extra关于MYSQL如何解析查询的额外信息。将在表4.3中讨论,但这里可以看到的坏的例子是Using temporary和Using filesort,意思MYSQL根本不能使用索引,结果是检索会很慢extra列返回的描述的意义Distinct一旦MYSQL找到了与行相联合匹配的行,就不再搜索了Not existsMYSQL优化了LEFT JOIN,一旦它找到了匹配LEFT JOIN标准的行,就不再搜索了Range checked for eachRecord(index map:#)没有找到理想的索引,因此对于从前面表中来的每一个行组合,MYSQL检查使用哪个索引,并用它来从表中返回行。这是使用索引的最慢的连接之一Using filesort看到这个的时候,查询就需要优化了。MYSQL需要进行额外的步骤来发现如何对返回的行排序。它根据连接类型以及存储排序键值和匹配条件的全部行的行指针来排序全部行Using index列数据是从仅仅使用了索引中的信息而没有读取实际的行动的表返回的,这发生在对表的全部的请求列都是同一个索引的部分的时候Using temporary看到这个的时候,查询需要优化了。这里,MYSQL需要创建一个临时表来存储结果,这通常发生在对不同的列集进行ORDER BY上,而不是GROUP BY上Where used使用了WHERE从句来限制哪些行将与下一张表匹配或者是返回给用户。如果不想返回表中的全部行,并且连接类型ALL或index,这就会发生,或者是查询有问题不同连接类型的解释(按照效率高低的顺序排序)system表只有一行:system表。这是const连接类型的特殊情况const表中的一个记录的最大值能够匹配这个查询(索引可以是主键或惟一索引)。因为只有一行,这个值实际就是常数,因为MYSQL先读这个值然后把它当做常数来对待eq_ref在连接中,MYSQL在查询时,从前面的表中,对每一个记录的联合都从表中读取一个记录,它在查询使用了索引为主键或惟一键的全部时使用ref这个连接类型只有在查询使用了不是惟一或主键的键或者是这些类型的部分(比如,利用最左边前缀)时发生。对于之前的表的每一个行联合,全部记录都将从表中读出。这个类型严重依赖于根据索引匹配的记录多少—越少越好range这个连接类型使用索引返回一个范围中的行,比如使用&或FAQ1表中包含 10 万条记录,有一个 datetime 类型的字段。取数据的语句:SELECT * FROM my_table WHERE created_at & '';用 EXPLAIN 检查,发现 type 是 ALL, key 是 NULL,根本没用上索引。可以确定的是,created_at 字段设定索引了。什么原因呢?用 SELECT COUNT(*) 看了一下符合 WHERE 条件的记录总数,居然是 6W 多条!!难怪不用索引,这时用索引毫无意义,就好像 10 万条记录的用户表,有个性别字段,不是男就是女,在这种字段设置索引是错误的决定。稍微改造一下上述语句:SELECT * FROM my_table WHERE created_at BETWEEN '' AND '';这回问题解决!符合条件的记录只有几百条,EXPLAIN 的 type 是 range,key 是 created_at,Extra 是 Using where 。自己总结个准则,索引的目的就是尽量缩小结果集,这样才能做到快速查询。6万条记录符合条件,已经超出总记录数的一半,这时索引已经没有意义了,因此 MySQL 放弃使用索引。这与设置 gender 字段,并加上索引的情况相似,当你要把所有男性记录都选取出来,符合条件的记录数约占总数的一半,MySQL 同样不会使用这个索引。唯一值越多的字段,使用索引的效果越好。设置联合索引时,唯一值越多的,越应该放在“左侧”。
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具mysql 查看索引 查看表已建有的所有索引sql语句-mysql教程-ab蓝学网
mysql 查看索引 查看表已建有的所有索引sql语句
简介:数据库|mysql查看索引mysql&mysql&·Table表的名称。·
mysql 查看索引
mysql& sho
表的名称。
& Non_unique
如果索引不能包括重复词,则为0。如果可以,则为1。
& Key_name
索引的名称。
& Seq_in_index
索引中的列序列号,从1开始。
& Column_name
& Collation
列以什么方式存储在索引中。在MySQL中,有值‘A’(升序)或NULL(无分类)。
& Cardinality
索引中唯一值的数目的估计值。通过运行ANALYZE TABLE或myisamchk -a可以更新。基数根据被存储为整数的统计数据来计数,所以即使对于小型表,该值也没有必要是精确的。基数越大,当进行联合时,MySQL使用该索引的机 会就越大。
& Sub_part
如果列只是被部分地编入索引,则为被编入索引的字符的数目。如果整列被编入索引,则为NULL。
指示关键字如何被压缩。如果没有被压缩,则为NULL。
如果列含有NULL,则含有YES。如果没有,则该列含有NO。
& Index_type
用过的索引方法(BTREE, FULLTEXT, HASH, RTREE)。
转载注明本文地址:
上一编:下一编:}

我要回帖

更多关于 sql 查看索引语句 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信