mysql表添加索引

文章目录
      • 1.添加普通索引(INDEX)
      • [2.添加唯一索引(UNIQUE INDEX)](#2.添加唯一索引(UNIQUE INDEX))
      • [3.添加主键索引(PRIMARY KEY)](#3.添加主键索引(PRIMARY KEY))
      • [4.添加全文索引(FULLTEXT INDEX)](#4.添加全文索引(FULLTEXT INDEX))

在 MySQL 中,可以使用 ALTER TABLE 语句来为表添加索引。索引可以提高查询性能。以下是几种常见的添加索引的方式:

1.添加普通索引(INDEX)

语法:

复制代码
ALTER TABLE table_name ADD INDEX index_name(column_list);

例如,为名为 users 的表的 username 字段添加一个普通索引:

复制代码
ALTER TABLE users ADD INDEX idx_username(username);
2.添加唯一索引(UNIQUE INDEX)

确保索引列的值是唯一的。

语法:

复制代码
ALTER TABLE table_name ADD UNIQUE INDEX index_name(column_list);

例如,为 users 表的 email 字段添加唯一索引:

复制代码
ALTER TABLE users ADD UNIQUE INDEX idx_email(email);
3.添加主键索引(PRIMARY KEY)

一个表只能有一个主键索引,用于唯一标识表中的每一行。如果表中没有定义主键,可以使用 ALTER TABLE 添加。

语法:

复制代码
ALTER TABLE table_name ADD PRIMARY KEY(column_list);

例如,为 users 表的 id 字段添加主键索引:

复制代码
ALTER TABLE users ADD PRIMARY KEY(id);
4.添加全文索引(FULLTEXT INDEX)

用于对文本类型的列进行全文搜索。

语法:

复制代码
ALTER TABLE table_name ADD FULLTEXT INDEX index_name(column_list);

例如,为 articles 表的 content 字段添加全文索引:

复制代码
ALTER TABLE articles ADD FULLTEXT INDEX idx_content(content);

在添加索引时,需要考虑以下几点:

  • 索引会占用额外的存储空间。
  • 过多的索引可能会降低数据插入、更新和删除的性能。
  • 根据实际的查询需求选择合适的索引类型和列。

希望本文对你有所帮助!如果你有任何问题或建议,欢迎在评论区留言。

关注我看更多有意思的文章哦!???

相关推荐
Jim60016 小时前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL1 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
倔强的石头_1 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_4 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横4 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二4 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
冬奇Lab4 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
小猿姐4 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
ClouGence5 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle