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

SQL中对字符串字段模糊查询(LIKE)的索引命中情况

SQL中对字符串字段模糊查询(LIKE)的索引命中情况

在SQL数据库中,字符串字段上的索引是否会被LIKE查询使用取决于多种因素,包括数据库类型、索引结构、查询模式以及数据库配置。

主要数据库中的行为

1. MySQL/MariaDB

  • 前缀匹配(pattern%):可以使用B-tree索引
  • 后缀匹配(%pattern)包含匹配(%pattern%):不能使用标准索引
  • 特殊技巧
    -- 使用反向索引处理后缀查询
    ALTER TABLE users ADD COLUMN name_reverse VARCHAR(255);
    CREATE INDEX idx_name_reverse ON users(name_reverse);
    SELECT * FROM users WHERE name_reverse LIKE REVERSE('%son');
    

2. PostgreSQL

  • 前缀匹配:可以使用B-tree索引
  • 复杂模式:需使用pg_trgm扩展
    CREATE EXTENSION pg_trgm;
    CREATE INDEX idx_name_trgm ON users USING gin(name gin_trgm_ops);
    

3. SQL Server

  • 前缀匹配:可以使用索引
  • 包含匹配:可以尝试使用全文索引(FULLTEXT)
    CREATE FULLTEXT INDEX ON users(name);
    

4. Oracle

  • 前缀匹配:可以使用索引
  • 复杂模式:可以使用Oracle Text功能

通用优化建议

  1. 尽量使用前缀匹配LIKE 'abc%'LIKE '%abc'效率高

  2. 考虑使用函数索引(如反向索引)

  3. 对于复杂搜索

    • 使用专门的全文搜索引擎(如Elasticsearch)
    • 使用数据库特定的全文搜索功能
  4. 检查执行计划

    EXPLAIN SELECT * FROM table WHERE column LIKE 'pattern%';
    

何时索引会被使用

查询模式是否可能使用索引
LIKE 'abc%'✅ 是
LIKE '%abc'❌ 否
LIKE '%abc%'❌ 否
LIKE 'abc' (无通配符)✅ 是(等同于=)

高级解决方案

  1. 使用计算列+索引

    ALTER TABLE users ADD name_length AS LENGTH(name);
    CREATE INDEX idx_name_length ON users(name_length);
    
  2. 使用分区表:按字符串前缀分区

  3. 使用专门的搜索引擎:如Elasticsearch、Solr等

记住,索引的使用还取决于数据库优化器的决策,实际应以EXPLAIN分析结果为准。

http://www.xdnf.cn/news/15530.html

相关文章:

  • 第3章 Excel表格格式设置技巧
  • Win11专业工作站版安装配置要求
  • [NOIP][C++] 树的重心
  • Word 文档合并利器:基于 org.docx4j 的 Java 实现全解析
  • Java线程创建与运行全解析
  • GraphQL与REST在微服务接口设计中的对比分析与实践
  • Windows 启动后桌面黑屏,其他程序正常运行
  • Java接口:小白如何初步认识Java接口?
  • 一点点dd
  • WPF 加载和显示 GIF 图片的完整指南
  • 聚焦AI与物流核心技术:2025智慧物流论坛及长三角快递物流展会9月上海开幕
  • API Gateway HTTP API 控制客户端访问 IP 源
  • CSV 字段映射小工具 Demo
  • Thymeleaf 基础语法与标准表达式详解
  • 安全初级作业2
  • Linux LVS集群技术详解与实战指南
  • 测试工作中的质量门禁管理
  • HTML基础P1 | HTML基本元素
  • 【游戏引擎之路】登神长阶(十九):3D物理引擎——岁不寒,无以知松柏;事不难,无以知君子
  • 【uni-ui】hbuilderx的uniapp 配置 -小程序左滑出现删除等功能
  • Django+Celery 进阶:Celery可视化监控与排错
  • 健康生活,从细节开始
  • Linux运维常用命令大全
  • JS的防抖与节流
  • 实例操作:基于 PipeLine 实现 JAVA项目集成 SonarQube代码检测通知 Jenkins
  • 基于R、Python的Copula变量相关性分析
  • 开源 python 应用 开发(七)数据可视化
  • 网络编程/Java面试/TCPUDP区别
  • Spring Boot 解决跨域问题
  • langchain--1--agent示例