news 2026/4/3 13:46:49

MySQL 知识点:函数索引(Functional Index)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL 知识点:函数索引(Functional Index)

MySQL 技术文档:函数索引(Functional Index)

1. 概述

在 MySQL 8.0.13 之前,索引必须关联到表的列或列的前缀。如果查询条件对列使用了函数(如WHERE UPPER(name) = 'TOM'),即使name字段有索引,该索引也会失效。

函数索引允许在表达式或函数的结果上建立索引,从而使原本无法利用索引的复杂查询实现高性能。

2. 语法结构

创建函数索引的语法与普通索引类似,区别在于索引部分被包含在双括号内。

2.1 创建表时定义

CREATETABLEusers(idINTPRIMARYKEY,first_nameVARCHAR(50),last_nameVARCHAR(50),-- 创建函数索引:存储全名的长度INDEXidx_name_len((LENGTH(CONCAT(first_name,last_name)))));

2.2 在现有表上添加

ALTERTABLEt_erp_doc_credentialADDUNIQUEINDEXuk_active_code((IF(del_flag=1,credential_code,NULL)));

3. 实现原理

MySQL 内部将函数索引实现为隐藏的虚拟生成列(Virtual Generated Column)

  1. 当数据插入或更新时,MySQL 自动计算表达式的结果。
  2. 计算后的结果被存储在 B+ 树索引结构中。
  3. 优化器在解析 SQL 时,如果发现WHERE条件中的表达式与函数索引定义的表达式完全匹配,则直接引用该索引。

4. 关键应用场景

4.1 逻辑删除下的唯一性约束

这是最经典的应用。在包含逻辑删除字段(如del_flag)的表中,要求“未删除的数据唯一,已删除的数据可重复”。

  • 表达式UNIQUE INDEX ((IF(del_flag = 1, code, NULL)))
  • 原理:MySQL 唯一索引允许存在多个NULL值。

4.2 大写/小写不敏感查询

如果数据库字符集区分大小写,但业务需要快速进行不区分大小写的搜索:

  • 表达式INDEX ((UPPER(user_email)))

4.3 JSON 字段检索

针对 JSON 类型的某个 key 进行高频查询:

  • 表达式INDEX ((CAST(json_col->>'$.user_name' AS CHAR(30))))

5. 局限性与注意事项

5.1 语法严格匹配

查询 SQL 中的表达式必须与索引定义的表达式完全一致

  • 有效WHERE UPPER(name) = 'A'匹配INDEX ((UPPER(name)))
  • 无效WHERE name = 'a'无法直接利用INDEX ((UPPER(name)))

5.2 性能开销

  • 写入性能:每次INSERTUPDATE都会触发表达式计算,略微增加 CPU 负担。
  • 存储空间:虽然不增加可见列,但索引本身会在磁盘(.ibd文件)中占用空间。

5.3 算法限制

  • 函数索引不支持ALGORITHM=INPLACE。添加该索引时通常会触发COPY算法(锁表),在生产环境大型表操作时需谨慎。

5.4 维护规范

  • 函数索引中的函数必须是确定性函数(Deterministic)。例如,不能使用NOW()RAND(),因为它们的值随时间改变。
  • 主键不能是函数索引。

6. 性能验证

使用EXPLAIN命令观察Extra列。如果看到Using indexkey命中,说明函数索引生效。

EXPLAINSELECT*FROMusersWHERELENGTH(CONCAT(first_name,last_name))>10;

7. 总结

函数索引是 MySQL 8.0 迈向现代数据库的重要一步。它不仅减少了冗余物理列的创建(原本需要手动创建生成列再加索引),还为复杂的业务逻辑优化提供了极大的灵活性。

建议:在处理逻辑删除唯一性、JSON 搜索或历史遗留的复杂查询优化时,优先考虑函数索引。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/1 0:02:05

当微电网遇上鲁棒优化:一场和不确定性硬刚的实战

微电网两阶段鲁棒优化经济调度程序 关键词:微网优化调度 两阶段鲁棒 CCG算法 经济调度 参考文档:《微电网两阶段鲁棒优化经济调度方法》 仿真平台:MATLAB YALMIPCPLEX 主要内容:构建了微网两阶段鲁棒调度模型,建立了mi…

作者头像 李华
网站建设 2026/3/28 5:27:06

国产数据库:从替代到引领,重塑数字经济核心底座

目录 一、市场爆发:3.3万亿信创浪潮下的国产崛起 二、技术破壁:从“二次开发”到“原生创新”的跨越 1. 分布式架构:支撑海量高并发场景 2. 云原生融合:实现极致弹性与成本优化 3. 多模与AI融合:拓展场景适配能力…

作者头像 李华
网站建设 2026/4/3 3:59:45

西湖大学突破:大模型“模仿-探索“两阶段训练法效果更优

这项由西湖大学工程学院丁博文、陈宇涵等研究者联合华为诺亚方舟实验室共同完成的研究,发表于2025年12月的arXiv预印本(编号:arXiv:2512.11470v1),对当前大语言模型的训练方式提出了根本性的重新思考。有兴趣深入了解的…

作者头像 李华
网站建设 2026/3/28 22:04:58

基于大数据的全国降水分析可视化系统的设计与实现(毕设源码+文档)

背景 本课题聚焦全国降水数据价值挖掘与直观呈现的核心需求,针对当前全国降水数据体量庞大、区域覆盖广、处理效率低下、可视化效果单一、数据解读门槛高、防汛抗旱等场景缺乏精准数据支撑等痛点,设计开发基于大数据的全国降水分析可视化系统。系统以大数…

作者头像 李华
网站建设 2026/3/31 2:45:05

我发现大文件HTTP上传阻塞 后来才知道用分块编码流式传输

💓 博客主页:瑕疵的CSDN主页 📝 Gitee主页:瑕疵的gitee主页 ⏩ 文章专栏:《热点资讯》 目录我和Node.js的相爱相杀史:从“Hello World”到深夜崩溃指南 一、初遇Node.js:你以为你在学后端&…

作者头像 李华