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

sql添加索引

1.基础使用

1.普通索引 添加INDEX
ALTER TABLE table_name ADD INDEX index_name ( column )

下面演示下给user表的name字段添加一个索引

2.主键索引 添加PRIMARY KEY
ALTER TABLE table_name ADD PRIMARY KEY ( column )

3.唯一索引 添加UNIQUE
ALTER TABLE table_name ADD UNIQUE ( column )

4.全文索引 添加FULLTEXT
ALTER TABLE table_name ADD FULLTEXT ( column)

5.如何添加多列索引
ALTER TABLE table_name ADD INDEX index_name ( column1, column2, column3 )

索引是数据库中用于提高查询效率的重要工具。MySQL的索引类型包括B-tree索引、哈希索引、全文索引等。在实际使用中,我们经常需要增加索引来优化查询性能。MySQL提供了CREATE INDEX和ALTER TABLE两种SQL语句来增加索引。

2.1 CREATE INDEX
CREATE INDEX语句用于在已有的表中增加索引。它的语法如下:

CREATE [UNIQUE] [INDEX|KEY] index_name
    USING index_type(column_name[(length)]) [ASC|DESC];
UNIQUE关键字用于指定索引是否唯一。如果不指定该关键字,则索引可以包含重复的值。
INDEXKEY关键字用于指定索引的类型。常用的索引类型有B-tree索引、哈希索引、全文索引等。
index_name是索引的名称。
index_type是索引的类型。
column_name是要建立索引的列名,可以指定多个列名。
length是可选的参数,用于指定索引字段的长度。
ASCDESC关键字用于指定索引的排序方式,默认为ASC

下面是一个使用CREATE INDEX语句增加B-tree索引的例子:

CREATE INDEX idx_name ON table_name (column_name);

2.2 ALTER TABLE
ALTER TABLE语句用于在已有的表中增加索引。它的语法如下:

ALTER TABLE table_name
    ADD [UNIQUE] [INDEX|KEY] index_name
    USING index_type(column_name[(length)]) [ASC|DESC];

与CREATE INDEX相比,ALTER TABLE语句在增加索引的同时还可以指定要增加索引的表名。

下面是一个使用ALTER TABLE语句增加B-tree索引的例子:

ALTER TABLE table_name
    ADD INDEX idx_name (column_name);
  1. 增加索引的实例
    下面通过一个实例来演示如何使用MySQL的SQL语句增加索引。

假设我们有一个名为users的表,其中包含了用户的信息。我们想要根据用户的年龄来进行快速查找,因此可以为users表的age列增加索引。

首先,我们可以使用CREATE INDEX语句来增加索引:

CREATE INDEX idx_age ON users (age);

如果我们已经创建了users表,可以使用ALTER TABLE语句来增加索引:

ALTER TABLE users
ADD INDEX idx_age (age);

增加索引后,我们可以使用EXPLAIN语句来查看查询的执行计划。例如,我们可以查看使用索引后查询年龄小于30的用户的执行计划:

EXPLAIN SELECT * FROM users WHERE age < 30;
  1. 注意事项
    在增加索引时,需要注意以下几点:

增加索引会增加磁盘空间的使用。因此,不要盲目地为所有列都增加索引,而是根据实际需求选择增加索引的列。
索引不适用于所有类型的查询。对于一些频繁更新的列,增加索引可能会降低性能,因为更新索引需要耗费额外的时间。
当增加索引后,数据库在插入、更新和删除数据时需要维护索引,因此可能会导致写入操作变慢。因此,需要权衡索引的读写性能,根据实际情况进行调整。


http://www.kler.cn/a/136446.html

相关文章:

  • 在ubuntu上如何使用sdkman安装两个版本的java并进行管理和维护
  • el-select使用enter选中触发了另一个enter方法
  • OpenCV相机标定与3D重建(53)解决 Perspective-3-Point (P3P) 问题函数solveP3P()的使用
  • MMDetection框架下的常见目标检测与分割模型综述与实践指南
  • [0405].第05节:搭建Redis主从架构
  • vue3+ts+element-plus 对话框el-dialog设置圆角
  • C++多线程编程:其六、unique_lock的使用
  • 【寒武纪(14)】硬件系统由标量指令、向量指令、张量指令、访存指令构成
  • BUUCTF [BJDCTF2020]一叶障目 1
  • 在服务器上部署MVC 6应用程序
  • 关于使用宝塔页面Nginx的一些注意事项:Nginx不生效情况,以及解决方案
  • 11.20 知识总结(choices参数、MVC和MTV的模式、Django与Ajax技术)
  • NameServer源码解析
  • milvus采坑一:启动服务就会挂掉
  • HashMap的详细解读
  • Vue3--Vue Router详解--学习笔记
  • Vue使用基本教程(基本介绍及对比,初步使用,构建项目,编辑器等)
  • 云计算赛项容器云2023搭建
  • Conditional GAN
  • Python如何将项目直接打包为一键整合包
  • C语言--给定一行字符串,获取其中最长单词【图文详解】
  • 记GitLab服务器迁移后SSH访问无法生效的问题解决过程
  • NX二次开发UF_CAM_ask_lower_limit_plane_status 函数介绍
  • 【PyQt小知识 - 3】: QComboBox下拉框内容的设置和更新、默认值的设置、值和下标的获取
  • 【Kingbase FlySync】命令模式:安装部署同步软件,实现KES到KES实现同步
  • vscode设置前进、后退快捷键