什么是
索引:索引是数据库存储
引擎用于快速查找到指定数据的一种数据结构。可以用新华字典做类比:如果新华字典中对每个字的详细解释是数据库中表的记录,那么按部首或拼音等排序的目录就是索引,使用它可以让我们快速查找的某一个字详细解释的位置。在MySQL中,存储引擎也是用了类似的方法,先在索引中找到对应的值,然后再根据匹配的索引值找到对应表中记录的位置。面试中为什么问索引:之所以在索引在面试中经常被问到,就是因为:索引是数据库的良好
性能表现的关键,也是对查询能优化最有效的手段。索引能够轻易地把查询性能提高几个数量级。然而,糟糕的索引也同样会影响查询性能,当表中的数据量越来越多的时候,索引对性能的影响就越大。在数据量比较少并且负责比较低的时候,糟糕的索引对性能的影响可能不明显,但是当数据量逐渐增多的时候,性能会急剧下降。索引的类型:不同类型的索引,可以为不同场景提供更好的性能。在MySQL中,索引是在存储引擎层面实现的,而不是在服务器层面实现的。正如大家所知道,MySQL支持多种类型的存储引擎。所以,在不同存储引擎中索引的实现方式并不是一样的,也不是所有类型的索引都被所有存储引擎支持的,即使多个存储引擎支持同一种类型的索引,它底层的实现也有可能是不相同的。
定义:存在于关系型数据库中,是一种与表有关的数据库对象
以存储方式分类可以分为
B*树
位图
优点:提高检索速度
使用原则(何时需要创建索引):
哪些表需要创建索引:
某表常被访问或某表数据量较大
通常以哪些字段作为索引:
某字段常被作为查询条件
评论列表(0条)