mysql怎么查表索引 mysql查看表索引命令( 二 )


索引的优缺点
索引有其明显的优势,也有其不可避免的缺点 。
优点
索引的优点如下:
1、通过创建唯一索引可以保证数据库表中每一行数据的唯一性 。
2、可以给所有的 MySQL 列类型设置索引 。
3、可以大大加快数据的查询速度,这是使用索引最主要的原因 。
4、在实现数据的参考完整性方面可以加速表与表之间的连接 。
5、在使用分组和排序子句进行数据查询时也可以显著减少查询中分组和排序的时间
缺点
增加索引也有许多不利的方面 , 主要如下:
1、创建和维护索引组要耗费时间,并且随着数据量的增加所耗费的时间也会增加 。
2、索引需要占磁盘空间,除了数据表占数据空间以外,每一个索引还要占一定的物理空间 。如果有大量的索引,索引文件可能比数据文件更快达到最大文件尺寸 。
3、当对表中的数据进行增加、删除和修改的时候,索引也要动态维护,这样就降低了数据的维护速度 。
使用索引时,需要综合考虑索引的优点和缺点 。
Mysql-多表查询as索引方法
(1) 根据需求找到关联表
(2)找到关联条件
重点的表tables
* 需求1:统计world库下有几个表
需求2:统计所有库下表的个数
需求3:统计每个库的总数据大小
--单表占空间:AVG_ROW_LENGTH*TABLE_ROWS+INDEX_LENGTH
什么使索引:索引其实就是一种算法
BTree
HASH
Rtree
Fulltext
辅助索引
辅助索引只提取索引列作为叶子节点
聚集索引
聚集索引提取整行数据作为叶子节点
1、辅助索引和聚集索引最大的区别就在于叶子节点 , 枝节点和根节点原理相同
2、辅助索引会记录主键值,一般情况(除等值查询),最终都会通过聚集索引(主键)来找到需要的数据
第二种
一般经常用来查询的列作为索引
索引可以有多个,但是索引名不可重名
第一种:单列索引
第二种:前缀索引
前缀索引只能应用到字符串列,数字列不能用前缀索引
联合索引说明:如果在一个表内对A、B、C三个列创建联合索引那么创建索引将按照如下情况创建索引表:
A
AB
ABC
======================================================
(1)查询列无索引
(2)语句不符合走走索引条件
(3)需要查看全表
即把有索引的列全便利一遍
、 、 =、 =、 like、 between and 在范围扫描中,这些会受到B+tree索引叶子节点上额外的优化 , 因为这些是连续取值的
or、in 这两个不是连续的取值,所以不能受到B+tree索引的额外优化,使用时相当于Btree索引
!=、 not in 只有在主键列才走索引也是range级别
(1)、 、 =、 =、 like、 between and
(2)or、in
(3)!=、 not in
多表连接查询 , 非驱动表连接条件是主键或唯一键
一般多表查询的时,最左侧的表为驱动表,右侧的为非驱动表,下边的例子中country标为非驱动表
7.1.1 数字类型
7.1.2 字符串类型:
字符集
中文
gbk 2字节
utf8 3字节
utf8mb4 4字节
utf8mb4 为例:
举例(1)联合索引等值查询
举例(2) 联合索引中有不等值查询
如果Extra列出现Using temporary、Using filesort,两项内容,那么考虑以下语句的问题 。
group by
order by
distinct
join on
union
如何查看MySQL索引查看索引
mysql show index from tblname;
mysql show keys from tblname;
· Table
表的名称 。
· Non_unique
如果索引不能包括重复词,则为0 。如果可以,则为1 。

推荐阅读