当前位置: 首页 > news >正文

MySQL索引的类型有哪些?

分析&回答

从功能逻辑角度,可分为:

  • 普通索引 INDEX(普通索引)     ALTER TABLE table_name ADD INDEX index_name ( column )
  • 唯一索引 UNIQUE(唯一索引)     ALTER TABLE table_name ADD UNIQUE (column)
  • 主键索引 PRIMARY KEY(主键索引)  ALTER TABLE table_name ADD PRIMARY KEY ( column )
  • 组合索引 组合索引   ALTER TABLE table_name ADD INDEX index_name ( column1column2column3 )
  • 全文索引 FULLTEXT(全文索引)      ALTER TABLE table_name ADD FULLTEXT ( column )

从数据结构角度,可分为:

  • B+树索引
  • hash索引
  • 全文索引
  • 空间数据索引(R-Tree索引)(不要求

从物理存储角度,可分为:

  • 聚簇索引
  • 非聚簇索引

反思&扩展

说说数据库索引类型?(Oracle)

逻辑上:

  • Single column 单行索引
  • Concatenated 多行索引
  • Unique 唯一索引
  • NonUnique 非唯一索引
  • Function-based函数索引
  • Domain 域索引

物理上:

  • Partitioned 分区索引
  • NonPartitioned 非分区索引
  • B-tree:
  • Normal 正常型B树
  • Rever Key 反转型B树 
  • Bitmap 位图索引

索引结构:

B-tree:

  • 适合与大量的增、删、改(OLTP);
  • 不能用包含OR操作符的查询;
  • 适合高基数的列(唯一值多)
  • 典型的树状结构;
  • 每个结点都是数据块;
  • 大多都是物理上一层、两层或三层不定,逻辑上三层;
  • 叶子块数据是排序的,从左向右递增;
  • 在分支块和根块中放的是索引的范围;

Bitmap:

  • 适合与决策支持系统;
  • 做UPDATE代价非常高;
  • 非常适合OR操作符的查询; 
  • 基数比较少的时候才能建位图索引;

B*tree索引的话通常在访问小数据量的情况下比较适用,比如你访问不超过表中数据的5%,当然这只是个相对的比率,适用于一般的情况。bitmap的话在数据仓库中使用较多,用于低基数列,比如性别之类重复值很多的字段,基数越小越好。

喵呜面试助手:一站式解决面试问题,你可以搜索微信小程序 [喵呜面试助手] 或关注 [喵呜刷题] -> 面试助手 免费刷题。如有好的面试知识或技巧期待您的共享!

http://www.lryc.cn/news/158722.html

相关文章:

  • 【JavaScript】在指定dom元素前面创建标签元素
  • ARMv8 TTBRx寄存器
  • C51智能小车(循迹、跟随、避障、测速、蓝牙、wifie、4g、语音识别)总结
  • 回归预测 | MATLAB实现PCA-BP主成分降维结合BP神经网络多输入单输出回归预测
  • Kubernetes(k8s)部署高可用多主多从的Redis集群
  • 算法专题:前缀和
  • bs4库爬取天气预报
  • l8-d8 TCP并发实现
  • 编写中间件以用于 Express 应用程序
  • 【2023年数学建模国赛】D题解题思路
  • python爬虫之正则表达式学习
  • 智慧能源方案:TSINGSEE青犀AI算法中台在能源行业的应用
  • 达梦数据库awr报告收集
  • c语言练习43:深入理解strcmp
  • NUC980webServer开发
  • 驱动开发--day2
  • 用户促活留存新方式——在APP中嵌入小游戏
  • MySQL 8.0.34(x64)安装笔记
  • 物流供应商实现供应链自动化的3种方法
  • Mysql更新时间列只改日期为指定日期不更改时间
  • 实时测试工具 Visual Studio 扩展 NCrunch 4.18 Crack
  • Neo4j 基本语法
  • docker常见面试题
  • 静态路由:配置和使用详解
  • 玩转Mysql系列 - 第15篇:详解视图
  • 0065__git fetch, git pull, git merge, git rebase
  • AJAX学习笔记4解决乱码问题
  • 【23种设计模式】享元模式【⭐】
  • 语音信号的仿真原理
  • VLDB 2023 | CDSBen: 字节跳动 veDB 数据库存储系统性能测试模型