php面试专题---Mysql索引类型、介绍及优点
php面试专题---Mysql索引类型、介绍及优点
一、总结
一句话总结:
精品视频讲解里面的资料来源也是通过各种资料,比如博客、书等,只不过是基于讲解者的知识体系有整理的过程
1、B-Tree索引三大优点?
1、索引大大减少服务器扫描的数据量
2、索引帮助服务器避免排序和临时表
3、索引可以减少随机I/O变为顺序I/O
2、索引是否为最好的解决方案?
1、非常小的表,大部分情况全表扫描更高效
2、中到大型表,索引非常有效
3、特大表【TB级别】,可使用分区技术,块级元数据技术替换索引
二、Mysql索引类型、介绍及优点(转)
转自:Mysql索引类型、介绍及优点 - 简书
https://www.jianshu.com/p/e9844e5d7e68
写在前面:
网上针对索引分类,各种定义混乱,现在针对索引分类做以下整理。不足的地方,欢迎大家指正。
在MySql中,索引是在存储引擎层而不是服务器层实现的。
一、索引类型分类:
1. B-Tree索引
相关定义及原理
B-Tree树索引通常意味着所有的值都是按顺序存储的,并且每一个叶子页到根的距离都是相同。
B-Tree树索引能够加快访问速度,因存储引擎不必进行全表扫描获取数据,而是从索引的根节点开始搜索。根节点的槽中存放了指向子节点的指针,存储引擎根据这些指针向下层查找。 通过比较节点页的值和要查找的值可以找到合适的指针进入下层子节点,这些指针实际上定义了子节点页中值得上限和下限。最终存储引擎要么找到对应的值,要么该记录不存在。
树的深度跟表的大小直接相关。
可使用B-tree索引的类型
适用类型:全键值、键值范围、键前缀【只适用最左前缀,这是Mysql相关特性,甚至和版本有关】
因为索引树中节点是有序的,故可按键值查找、ORDER BY顺序查找。
B-Tree索引限制
- 没有按照索引的最左前缀查找
- 不能跳过索引的列
- 某个列范围查找,则右边所有列都无法使用索引查找。如下方案例:
WHERE name='zhangsan' AND city LIKE 'shen%' AND `date` ='2019-12-07'
2. 哈希索引
哈希索引基于哈希表实现,只有精确匹配索引所有列的查询才有效。
每一行,存储引擎都会对所有列计算一个哈希码,哈希码是较小的值,并且不同键值的行计算出来的哈希码也不一样。
在MySql中,只有Memory引擎显示支持哈希索引。也是Memory的默认索引类型,同时也支持B-Tree索引。
Memory引擎支持非唯一索引。
哈希索引限制
- 哈希索引只包含值和行指针,而不存储字段值,故不能使用索引中的值来避免读取行。
- 哈希索引无法用于排序,因哈希索引不是按照索引顺序存储。
- 哈希索引不支持部分索引匹配查找,因哈希索引始终是使用索引列的全部内容来计算哈希值。
3. 全文索引
通过关键字匹配来进行查询过滤,基于相似度来查询。全文索引基本原理列斯互联网搜索引擎。
待进一步完善...
4. 空间索引
MyISAM表支持空间索引,可用于地理数据存储。
二、索引优点
1. B-Tree索引三大优点:
索引大大减少服务器扫描的数据量
索引帮助服务器避免排序和临时表
索引可以减少随机I/O变为顺序I/O
2. 索引的“三星系统”
索引将相关记录放到一起则获得一星
索引中数据顺序和查找排序一直则获得二星
索引中列包含查询中需要的全部列则三星
3. 索引是否为最好的解决方案
非常小的表,大部分情况全表扫描更高效
中到大型表,索引非常有效
特大表【TB级别】,可使用分区技术,块级元数据技术替换索引
文末索引点缀
全值匹配我最爱,最左前缀要遵守;
带头大哥不能死,中间兄弟不能断;
索引列上少计算,范围之后全失效;
LIKE百分写最右,覆盖索引不写星;
不等空值还有or,索引失效要少用。
php面试专题---Mysql索引类型、介绍及优点的更多相关文章
- php面试专题---Mysql索引原理及SQL优化
php面试专题---Mysql索引原理及SQL优化 一.总结 一句话总结: 注意:只写精品 1.为表设置索引要付出代价 是什么? 存储空间:一是增加了数据库的存储空间 修改插入变动索引时间:二是在插入 ...
- php面试专题---MySQL常用SQL语句优化
php面试专题---MySQL常用SQL语句优化 一.总结 一句话总结: 原理,万变不离其宗:其实SQL语句优化的过程中,无非就是对mysql的执行计划理解,以及B+树索引的理解,其实只要我们理解执行 ...
- php面试专题---mysql数据库分库分表
php面试专题---mysql数据库分库分表 一.总结 一句话总结: 通过数据切分技术将一个大的MySQLServer切分成多个小的MySQLServer,既攻克了写入性能瓶颈问题,同一时候也再一次提 ...
- php面试专题---MySQL分区
php面试专题---MySQL分区 一.总结 一句话总结: mysql的分区操作还比较简单,好处是也不用自己动手建表进行分区,和水平分表有点像 1.mysql分区简介? 一个表或索引-->N个物 ...
- php面试专题---MYSQL查询语句优化
php面试专题---MYSQL查询语句优化 一.总结 一句话总结: mysql的性能优化包罗甚广: 索引优化,查询优化,查询缓存,服务器设置优化,操作系统和硬件优化,应用层面优化(web服务器,缓存) ...
- MySQL索引类型总结和使用技巧以及注意事项
索引是快速搜索的关键.MySQL索引的建立对于MySQL的高效运行是很重要的.下面介绍几种常见的MySQL索引类型 在数据库表中,对字段建立索引可以大大提高查询速度.假如我们创建了一个 mytable ...
- mysql进阶(二十六)MySQL 索引类型(初学者必看)
mysql进阶(二十六)MySQL 索引类型(初学者必看) 索引是快速搜索的关键.MySQL 索引的建立对于 MySQL 的高效运行是很重要的.下面介绍几种常见的 MySQL 索引类型. 在数 ...
- mysql索引类型(按存储结构划分)
关于mysql索引类型,网上有很多相关的介绍,给人的感觉很乱.鄙人在翻阅相关书籍后,特意梳理了一下.哪里有不对的地方,欢迎指正! 1. B-Tree索引 它使用B-Tree数据结构来存储数据,实际上很 ...
- mysql索引类型 normal, unique, full text
问题1:mysql索引类型normal,unique,full text的区别是什么? normal:表示普通索引 unique:表示唯一的,不允许重复的索引,如果该字段信息保证不会重复例如身份证号用 ...
随机推荐
- UDP信号驱动IO
SIGIO信号 信号驱动式I/O不适用于TCP套接字, 因为产生的信号过于频繁且不能准确判断信号产生的原因. 设置信号驱动需把sockfd的非阻塞与信号驱动属性都打开 server sockfd单独提 ...
- 腾讯视频的手机端的地址和PC端的地址是不一样的
腾讯视频的手机端的地址和PC端的地址是不一样的,所以使用iframe的时候记得要使用手机端的地址
- linux自动化运维工具Ansible saltstack Puppet、Chef、Fabric之间的对比
发现分布式是一个发展的趋势,无论是大型网站的负载均衡架构还是大数据框架部署,以及云存储计算系统搭建都离不开多台服务器的连续部署和环境搭建. 当我们的基础架构是分散式或者基于云的,并且我们经常需要处理在 ...
- Java数据结构介绍(线性结构和非线性结构)
数据结构包括:线性结构和非线性结构. 线性结构 数据元素之间存在一对一的线性关系 包括顺序存储结构和链式存储结构.顺序存储的线性表称为顺序表,顺序表中的存储元素是连续的 链式存储的线性表称为链表,链表 ...
- SCUT - 365 - 鹏哥的数字集合 - wqs二分 - 斜率优化dp
https://scut.online/p/365 https://www.luogu.org/problemnew/solution/P2365 写这篇的时候还不是很明白,看一下这个东西. http ...
- CSS文字,文本,背景,盒模型等记录
文字: font-family:" "; /*设置字体*/ font-size:6px;/*设置文字字号*/ color:red;/*设置文字颜色*/ font-weight:bo ...
- go中基本数据类型的相互转换
代码 // 基本数据类型的相互转换 package main import ( // 如果一个包没有被使用过,但又不想去掉,可在包名前加"_ "表示忽略 // 比如:_ " ...
- 联想ideapad 310s如何进BIOS,换固态硬盘SSD,配置U盘启动,重装Win10系统
1. 如何进BIOS 关机情况下,捅一下Novo键,即可进入BIOS 2. 安装固态硬盘 Ideadpad 310S 本身自带的硬盘是5400转的机械硬盘,容量小速度慢.换的新的固态硬盘是SATA接口 ...
- error: must use ‘class’ tag to refer to type ‘XXX’ in this scope
开发环境: Qt Creator 4.8.2 在写程序的时候,遇到了编译器报错 error: must use 'class' tag to refer to type 'XXX' in this s ...
- git上传文件夹的问题
使用git上传文件夹一定要注意,文件夹里面至少有一个文件,因为git不能管理空文件夹 所以上传就会不成功