SQL教程(四):索引

在这里插入图片描述

索引

在关系数据库中,如果有上万甚至上亿条记录,在查找记录的时候,想要获得非常快的速度,就要使用索引。索引是关系数据表中对某一列/多个列的值进行预排序的数据结构。通过使用索引,可以让数据库系统不用扫描整个数据表,而是直接定位到符合条件的记录,大大提高了查询速度

索引的目的:提高查询速度

例:学生表

在这里插入图片描述
如果需要我们经常根据score来进行查询,那么就可以对score创建索引

ALTER TABLE students
ADD INDEX idx_score(score);

这其中idx_score是索引的名字,使用列score创建

也可以设置多个列

ALTER TABLE students
ADD INDEX idx_name_score(name, score);

索引的效率取决于索引列的值是否散列,即该列的值如果越不互相相同,则索引效率越高。反过来,如果记录的列存在大量相同的值,例如gender不是男就是女,那对该列创建索引意义不大

可以对一张表创建多个索引

  • 优点:在于提高了查询速度
  • 缺点:插入、更新和删除记录时,需要同时修改索引

主键,关系数据表会自动创建主键索引,使用主键索引的效率是最高的,因为主键会保证绝对唯一


唯一索引

在关系数据表中看上去唯一的列,例如:身份证、邮箱……。由于他们具有业务含义,因此不宜作为主键。但是,这些列根据业务需求,确实具有唯一约束(两个人身份证不能相同哦),这个时候可以给列添加一个唯一索引,利用UNIQUE字段

ALTER TABLE students
ADD UNIQUE INDEX uni_name(name)

设置了名字不重复


唯一约束

除了可以给某个列添加唯一索引,也可以添加唯一约束

没有索引了,只是添加了不能重复的约束

ALTER TABLE students
ADD CONSTRAINT uni_name UNIQUE(name);

这种情况下,name列没有索引,但是具有唯一性


小结

  • 对数据表创建索引可以提高查询速度
  • 通过创建唯一索引,可以保证某个列的值具有唯一性
  • 数据库索引对用户和应用程序而言都是透明的
限时福利1:原价 129 元,最后2天仅需 69 元!后天涨价至98元 限时福利2:购课进答疑群专享柳峰(刘运强)老师答疑服务 限时福利3:购课添加助教领取价值 800 元的编程大礼包 为什么需要掌握高性能的MySQL实战? 由于互联网产品用户量大、高并发请求场景多,因此对MySQL的性能、可用性、扩展性都提出了很高的要求。使用MySQL解决大量数据以及高并发请求已经是程序员的必备技能,也是衡量一个程序员能力和薪资的标准之一。 为了让大家快速系统了解高性能MySQL核心知识全貌,我为你总结了「高性能 MySQL 知识框架图」,帮你梳理学习重点,建议收藏! 【课程设计】 课程分为四大篇章,将为你建立完整的 MySQL 知识体系,同时将重点讲解 MySQL 底层运行原理、数据库的性能调优、高并发、海量业务处理、面试解析等。 一、性能优化篇: 主要包括经典 MySQL 问题剖析、索引底层原理和事务与锁机制。通过深入理解 MySQL索引结构 B+Tree ,学员能够从根本上弄懂为什么有些 SQL索引、有些不走索引,从而彻底掌握索引的使用和优化技巧,能够避开很多实战中遇到的“坑”。 二、MySQL 8.0新特性篇: 主要包括窗口函数和通用表表达式。企业中的许多报表统计需求,如果不采用窗口函数,用普通的 SQL 语句是很难实现的。 三、高性能架构篇: 主要包括主从复制和读写分离。在企业的生产环境中,很少采用单台MySQL节点的情况,因为一旦单个节点发生故障,整个系统都不可用,后果往往不堪设想,因此掌握高可用架构的实现是非常有必要的。 四、面试篇: 程序员获得工作的第一步,就是高效的准备面试,面试篇主要从知识点回顾总结的角度出发,结合程序员面试高频MySQL问题精讲精练,帮助程序员吊打面试官,获得心仪的工作机会。
©️2020 CSDN 皮肤主题: 撸撸猫 设计师:设计师小姐姐 返回首页