sql 中使用like%、函数导致索引失效的解决方案

2024-09-06 18:20

本文主要是介绍sql 中使用like%、函数导致索引失效的解决方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SELECTp1.*FROM cdr_voice_202407_0 AS p1 
WHERELENGTH( p1.calling_number ) < 11 AND p1.calling_number LIKE '%10086%'

上边的sql中如果 calling_number  是索引  会导致索引失效

涉及的 WHERE 子句有两个条件:

  1. LENGTH(p1.calling_number) < 11:这是对字符串长度的判断。
  2. p1.calling_number LIKE '%10086%':这是一个通配符匹配,且通配符 % 位于前后(全局匹配)。

对于这两个条件,如果有索引,它们的表现如下:

1. LENGTH(p1.calling_number) < 11

  • 索引失效:一般来说,使用函数(如 LENGTH)会导致索引失效,因为数据库无法利用常规的 B-tree 索引或其他索引类型。
  • 解决办法:可以考虑创建一个虚拟列生成列,然后在该列上创建索引。例如,创建一个虚拟列存储 calling_number 的长度,并在该列上创建索引。
ALTER TABLE cdr_voice_202409_0
ADD calling_number_len INT AS (LENGTH(calling_number)) VIRTUAL;

使用生成列(computed column),这些列可以基于已有的列进行计算 

MySQL 中的虚拟列

在 MySQL 中,你可以使用生成列(generated column)来创建虚拟列,生成列可以是存储的(即在物理上存储在磁盘中)或虚拟的(即动态计算的)。

GENERATED 列(虚拟列)是从 MySQL 5.7 及以上版本支持的。如果你使用的 MySQL 版本低于 5.7,将不支持这个功能。请先确认你的 MySQL 版本 

这样,在查询 LENGTH(calling_number) 时,数据库可以使用索引。

2. p1.calling_number LIKE '%10086%'

  • 索引失效:因为 % 放在了字符串的开头,常规的 B-tree 索引无法被有效使用。B-tree 索引是顺序索引,只有在字符串开头匹配时(例如 LIKE '10086%')才能利用索引。
  • 解决办法:
    • 全文索引(Full-Text Index):如果数据库支持全文索引(Oracle 使用 Text 索引,MySQL 支持 FULLTEXT 索引),你可以使用它来加速这种模式匹配。

    • ALTER TABLE cdr_voice_202409_0
      ADD FULLTEXT INDEX idx_calling_number (calling_number);
  • FULLTEXT:指定为全文索引类型。
  • idx_calling_number:是索引的名称,可以自行命名。
  • calling_number:是需要加全文索引的列。

 

总结

  • LIKE '%10086%' 更灵活,但对大数据集性能较差,因为它通常会导致全表扫描,无法利用索引。
  • MATCH ... AGAINST('10086') 依赖于全文索引,性能更高,但需要先为目标字段创建全文索引,适用于较大文本的关键词搜索。
  • MATCH(calling_number):表示要搜索的列。
  • AGAINST('10086'):表示要搜索的关键字。

优化后的sql为 

SELECT p1.*
FROM cdr_voice_202407_0 AS p1
WHERE LENGTH(p1.calling_number) < 11 AND p1.calling_number LIKE '%10086%'

 

 

这篇关于sql 中使用like%、函数导致索引失效的解决方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142773

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同