数据库索引(Mysql)

简述:数据库索引是加速数据检索,提高查询效率的一种数据结构

语法规则

创建索引

sql 复制代码
--通用语法规则
--[内容] 可选参数
--UNIQUE: 可选关键字,用于创建唯一索引,确保索引列的值是唯一的
CREATE [UNIQUE] INDEX 索引名
ON 表名(字段名,...)
[ASC | DESC];

--ASC/DESC: 可选参数,指定索引是升序还是降序。默认是升序。

创建非唯一索引

sql 复制代码
CREATE INDEX idx_employee_name ON employees(name);

创建唯一索引

sql 复制代码
CREATE UNIQUE INDEX idx_employee_email ON employees(email);

创建符合索引(多字段(列))

sql 复制代码
CREATE INDEX idx_employee_name_age ON employees(name, age);

删除索引

方法一:

sql 复制代码
DROP INDEX 索引名 ON 表名;

方法二:使用表名前缀

sql 复制代码
ALTER TABLE 表名 DROP INDEX 索引名;

查看索引

sql 复制代码
SHOW INDEX FROM 表名;

常见的索引原则

    1. 选择唯一性索引,唯一性索引的值是唯一的,可以更快速的通过该索引来确定某条记录。
    1. 为经常需要排序、分组和联合操作的字段建立索引。
    1. 为常用作为查询条件的字段建立索引。
    1. 限制索引的数目: 索引并非是越多越好,创建索引也需要耗费资源,一是增加了数据库的存储空间,二是在插入和删除时要花费较多的时间维护索引尽量使用数据量少的索引
    1. 如果索引的值很长,那么查询的速度会受到影响。尽量使用前缀来索引
    1. 如果索引字段的值很长,最好使用值的前缀来索引。
    1. 删除不再使用或者很少使用的索引
    1. 最左前缀匹配原则,非常重要的原则。
    1. 尽量选择区分度高的列作为索引区分度的公式是表示字段不重复的比例
    1. 索引列不能参与计算,保持列"干净":带函数的查询不参与索引。
    1. 尽量的扩展索引,不要新建索引
相关推荐
文牧之1 小时前
Oracle 审计参数:AUDIT_TRAIL 和 AUDIT_SYS_OPERATIONS
运维·数据库·oracle
篱笆院的狗1 小时前
如何使用 Redis 快速实现布隆过滤器?
数据库·redis·缓存
洛神灬殇2 小时前
【LLM大模型技术专题】「入门到精通系列教程」基于ai-openai-spring-boot-starter集成开发实战指南
网络·数据库·微服务·云原生·架构
小鸡脚来咯2 小时前
redis分片集群架构
数据库·redis·架构
christine-rr3 小时前
征文投稿:如何写一份实用的技术文档?——以软件配置为例
运维·前端·网络·数据库·软件构建
海尔辛3 小时前
SQL 基础入门
数据库·sql
betazhou4 小时前
有没有 MariaDB 5.5.56 对应 MySQL CONNECTION_CONTROL 插件
linux·数据库·mysql·oracle·mariadb
Elohim8155 小时前
数据库SQLite基础
数据库·sqlite
TDengine (老段)5 小时前
TDengine 支持的平台汇总
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
大熊猫侯佩5 小时前
由一个 SwiftData “诡异”运行时崩溃而引发的钩深索隐(四)
数据库·swiftui·apple watch