数据库 索引

Mysql的索引 事务 存储引擎

  1. 索引

概念

什么是索引:索引是一个排序的列表,列表当中存储的是所有的值和包含这个值的数据所在行的物理地址

索引的作用

加快查询作用,这是他主要的一个作用

  1. 利用索引数据库可以快速定位,大大加快查询速度。
  2. 表的数据很多,查询需要关联多个表,这个时候索引也可以提高查询速度
  3. 加快表与表之间的连接
  4. 使用分组和排序时,可以大大减少时间
  5. 可以提高数据库恢复数据时的速度

索引创建的原则

  1. 如果有索引,数据库会优先进行索引查询,然后定位数据,索引索引使用不当,反而会增加数据库的负担

主键,外键必须要有索引(创建好了主键和外键自动就是索引,不需要额外声明)

  1. 如果一个表超过了300行记录,必须要有索引,否则数据库会遍历表的所有数据。
  2. 互相之间有关联的表,在关联字段上应该设置索引
  3. 如果该字段的唯一性太差,不适合创建索引,最好是唯一且不重复的字段
  4. 更新太频繁的字段,不适合做索引。
  5. 经常被where条件匹配的字段,尤其是表数据较多的,应该创建索引
  6. 在经常进行(高级语句)group by (分组) order by (排序语句)的字段,要建立索引
  7. 索引的列的字段越小越好,大文本字段(长文本字段)不要建立字段

索引的类型

  1. 数 索引又叫 BTREE

如何查看表的索引

属性结构的索引,也是大部分数据库的默认索引类型。

根节点:数的最顶端分支节点

分支节点:指向索引里其他的分支节点,也可以是叶子结点

叶子结点:直接指向表里的数据行

哈希索引:散列索引,把任意长度的输入,通过散列算法变换成固定长度的输出,散列值----分别对应数据里的列和行 mosql的默认引擎:innodb 默认的索引类型就是Btree

Memory 引擎可以支持HASH,也是他的默认引擎

先算散列值,然后在对应,

相关推荐
这个DBA有点耶13 小时前
数据库管理工具+开发工具的融合:AI如何重塑DBA工作流?
开发语言·数据库·人工智能·sql·云计算·dba
小李云雾13 小时前
Redis 从入门到实战:核心知识点与架构搭建全解析
数据库·redis·架构
我叫张小白。13 小时前
Redis常用数据结构与命令详解
数据结构·数据库·redis
SelectDB13 小时前
- 别把懂语义和查事实混为一谈:企业级 Agent 真正缺的是什么?
数据库·数据分析·agent
Lao A(zhou liang)的菜园13 小时前
深入详细解释Oracle 全量 CHECKPOINT 与增量 CHECKPOINT
数据库·oracle
数据库小学妹13 小时前
异构数据库同步实战:如何打通Oracle/MySQL/SQL Server的数据孤岛
数据库·mysql·oracle
数据库知识分享者小北14 小时前
安全可靠数据库选型之阿里云 PolarDB MySQL 版V2.0
数据库·mysql·阿里云·国产数据库·polardb·安全可靠数据库·polardb-m
一只fish14 小时前
Oracle官方文档翻译《Database Concepts 26ai》第16章-数据库实例
数据库·oracle
艾莉丝努力练剑14 小时前
【Linux:文件】库的制作与原理进阶
linux·运维·服务器·网络·数据库·c++·人工智能
深念Y14 小时前
DeepSeek/MiMo 推理链缓存代理:从内存到 SQLite 的两级缓存架构实战
数据库·缓存·架构·sqlite·内存·优化·分层