数据库索引(Mysql)

server/2024/9/24 22:34:59/

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

语法规则

创建索引

--通用语法规则
--[内容] 可选参数
--UNIQUE: 可选关键字,用于创建唯一索引,确保索引列的值是唯一的
CREATE [UNIQUE] INDEX 索引名
ON 表名(字段名,...)
[ASC | DESC];--ASC/DESC: 可选参数,指定索引是升序还是降序。默认是升序。

创建非唯一索引

CREATE INDEX idx_employee_name ON employees(name);

创建唯一索引

CREATE UNIQUE INDEX idx_employee_email ON employees(email);

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

CREATE INDEX idx_employee_name_age ON employees(name, age);

 删除索引

方法一:

DROP INDEX 索引名 ON 表名;

方法二:使用表名前缀

ALTER TABLE 表名 DROP INDEX 索引名;

查看索引

SHOW INDEX FROM 表名;

常见的索引原则

  • 1. 选择唯一性索引,唯一性索引的值是唯一的,可以更快速的通过该索引来确定某条记录。
  • 2. 为经常需要排序、分组和联合操作的字段建立索引。
  • 3. 为常用作为查询条件的字段建立索引。
  • 4. 限制索引的数目: 索引并非是越多越好,创建索引也需要耗费资源,一是增加了数据库的存储空间,二是在插入和删除时要花费较多的时间维护索引尽量使用数据量少的索引
  • 5. 如果索引的值很长,那么查询的速度会受到影响。尽量使用前缀来索引
  • 6. 如果索引字段的值很长,最好使用值的前缀来索引。
  • 7. 删除不再使用或者很少使用的索引
  • 8. 最左前缀匹配原则,非常重要的原则。
  • 9. 尽量选择区分度高的列作为索引区分度的公式是表示字段不重复的比例
  • 10. 索引列不能参与计算,保持列干净:带函数的查询不参与索引。
  • 11. 尽量的扩展索引,不要新建索引

http://www.ppmy.cn/server/34677.html

相关文章

003 redis分布式锁 jedis分布式锁 Redisson分布式锁 分段锁

文章目录 Redis分布式锁原理1.使用set的命令时,同时设置过期时间2.使用lua脚本,将加锁的命令放在lua脚本中原子性的执行 Jedis分布式锁实现pom.xmlRedisCommandLock.javaRedisCommandLockTest.java 锁过期问题1乐观锁方式,增加版本号(增加版本…

数据结构(C):玩转链表

🍺0.前言 言C之言,聊C之识,以C会友,共向远方。各位博友的各位你们好啊,这里是持续分享数据结构知识的小赵同学,今天要分享的数据结构知识是链表,在这一章,小赵将会向大家展开聊聊链表…

拼多多标准推广怎么开出自然流量呢

拼多多标准推广开出自然流量的策略如下: 拼多多推广可以使用3an推客。3an推客(CPS模式)给商家提供的营销工具,由商家自主设置佣金比例,激励推广者去帮助商家推广商品链接,按最终有效交易金额支付佣金&…

05_G1垃圾收集器

G1垃圾收集器简介 垃圾优先 Garbage-First(G1)垃圾收集器面向多处理器机器,适用于大内存场景。它尝试在无需太多配置的情况下实现垃圾收集暂停时间目标,并同时实现高吞吐量。G1旨在通过适用于当前目标应用和环境的功能&#xff0…

LNMP部署wordpress

1.环境准备 总体架构介绍 序号类型名称外网地址内网地址软件02负载均衡服务器lb0110.0.0.5192.168.88.5nginx keepalived03负载均衡服务器lb0210.0.0.6192.168.88.6nginx keepalived04web服务器web0110.0.0.7192.168.88.7nginx05web服务器web0210.0.0.8192.168.88.8nginx06we…

No module named ‘yaml‘

报错解释: 这个错误表示Python无法找到名为yaml的模块。通常是因为没有安装处理YAML文件的库。 解决方法: 需要安装PyYAML库,这是Python中用于解析和生成YAML文件的一个广泛使用的库。 在命令行中运行以下命令来安装PyYAML: …

给c++小白的教程9:循环

老师给比纳瑞出了一道题。 给出 𝑛 和 𝑛 个整数 𝑎𝑖,求这 𝑛 个整数中最小值是什么。 由题意得,此题无论是顺序结构或是选择结构都连输入也解决不了。 这时候,我们就要用上循环…

FIFO Generate IP核使用——异步复位

FIFO Generator IP核提供了一个复位输入,当该输入被激活时,它会复位所有的计数器和输出寄存器。对于块RAM或分布式RAM实现,复位FIFO并不是必需的,可以在FIFO中禁用复位引脚。共有两种复位类型选项:异步复位和同步复位。…