数据库索引及其使用

        前一阵子,在数据库上吃了不少的亏,这次来总结一下数据库中的索引,对于提升大量数据的查询速度很有帮助。


一、为什么要用索引


        一般少量的数据,可能不是很明显,但是到了大量的数据马上就显示出来索引的有点了。我们在创建数据表主键的时候,会自动创建一个唯一性的索引,用来保证数据表中每一行的唯一性。

        可以通过索引的建立,大大加快数据检索的速度(查询),同时也可以加速表和表之间的联系,从而实现数据参考的完整性。

        索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针。更通俗的说,数据库索引好比是一本书前面的目录,能加快数据库的查询速度。上述SQL语句,在没有索引的情况下,数据库会遍历全部200条数据后选择符合条件的;而有了相应的索引之后,数据库会直接在索引中查找符合条件的选项。如果我们把SQL语句换成“SELECT * FROM article WHERE id=2000000”,那么你是希望数据库按照顺序读取完200万行数据以后给你结果还是直接在索引中定位呢?

        索引分为聚簇索引和非聚簇索引两种,聚簇索引是按照数据存放的物理位置为顺序的,而非聚簇索引就不一样了;聚簇索引能提高多行检索的速度,而非聚簇索引对于单行的检索很快。


二、索引的分类


        1、普通索引(非聚焦索引):是最基本的索引,没有任何限制。一般为BTree类型,也是我们大多数情况下用到的索引。

        2、唯一索引:与普通索引类似,索引列值必须唯一,但允许有空值。

        3、全文所以(FULLTEXT):FULLTEXT索引仅可用于 MyISAM 表;他们可以从CHAR、VARCHAR或TEXT列中作为CREATE TABLE语句的一部分被创建,或是随后使用ALTER TABLE 或CREATE INDEX被添加。对于较大的数据集,将你的资料输入一个没有FULLTEXT索引的表中,然后创建索引,其速度比把资料输入现有FULLTEXT索引的速度更为快。不过切记对于大容量的数据表,生成全文索引是一个非常消耗时间非常消耗硬盘空间的做法。

        4、单列索引、多列索引:多个单列索引与单个多列索引的查询效果不同,因为执行查询时,MySQL只能使用一个索引,会从多个索引中选择一个限制最为严格的索引。


三、聚焦和非聚焦索引


         

        上表很好的反应了聚合索引和非聚合索引的使用上的一些区别还有需要注意的地方,对于一些标记型字段都需要注意一下,不要建立没有意义的索引。


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
数据库索引数据库管理系统中的重要概念,面试中经常会涉及与索引相关的问题。以下是一些常见的数据库索引面试题及其答案: 1. 什么是数据库索引? 答:数据库索引是一种数据结构,用于快速查找和访问数据库中的数据。它类似于书籍的目录,通过提供键值和对应的数据位置,可以加速数据的检索和查询操作。 2. 为什么使用数据库索引? 答:数据库索引可以大大提高数据的检索效率。它通过创建索引结构,减少了数据库查询时需要扫描的数据量,从而加快了查询速度。索引还可以帮助优化排序、连接和聚合等操作。 3. 哪些列适合创建索引? 答:适合创建索引的列包括经常作为查询条件的列、经常进行连接(JOIN)操作的列、经常进行排序和分组的列,以及唯一性约束列等。对于频繁更新的列,如插入、删除和更新操作较多的列,不宜过多地创建索引。 4. 索引数据库性能有什么影响? 答:索引可以提高查询性能,加快数据检索速度。但同时也会带来一些负面影响,如增加了存储空间的占用、增加了数据插入、删除和更新的时间开销,以及在维护索引时可能导致的锁竞争问题。因此,在创建索引时需要权衡索引的好处与开销。 5. 请解释聚集索引和非聚集索引的区别。 答:聚集索引(Clustered Index)决定了数据在磁盘上的物理排序顺序,一个表只能有一个聚集索引。非聚集索引(Non-clustered Index)则是基于表中某一列或多列的值创建的索引,它不会改变数据在磁盘上的物理排序顺序,一个表可以有多个非聚集索引。 这些是一些常见的数据库索引面试题及其答案,希望对你有帮助!如果你还有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值