模糊查询 的深度技术解析

以下是 模糊查询 的深度技术解析,涵盖核心语法、通配符策略、性能优化及实战陷阱:


🔍 一、核心运算符:LIKE

SELECT * FROM 表名 
WHERE 列名 LIKE '模式字符串';

🎯 二、通配符详解

通配符作用示例匹配案例
%任意长度字符(含0字符)'张%'张三、张无忌、张
_单个字符'李_'李四、李雷(不匹配"李")
[ ]字符集合内单字符 (仅SQL Server)'[王李]%'王五、李四
[^ ]排除字符集合 (仅SQL Server)'[^0-9]%'中文、字母(排除数字开头)
📌 通用标准(MySQL/PgSQL/Oracle):
-- 匹配 "公司"结尾的字符串
WHERE company LIKE '%公司'  -- 匹配第二个字为"小"的姓名
WHERE name LIKE '_小%'     -- 匹配含下划线的文件名 (需转义)
WHERE file_name LIKE '%\_%' ESCAPE '\'  

⚠️ 三、关键注意事项

1. 大小写敏感性问题
数据库默认行为强制不敏感方案
MySQL取决于校对规则WHERE LOWER(name) LIKE '%abc%'
PostgreSQL区分大小写ILIKE 运算符
Oracle区分大小写WHERE UPPER(name) LIKE '%ABC%'
2. 通配符转义(通用方案)
-- 查找含 "20%" 的备注(如"折扣20%")
SELECT * FROM products 
WHERE notes LIKE '%20\%%' ESCAPE '\';  -- 定义'\'为转义符-- 查找含下划线的文件名
WHERE file_name LIKE '%\_%' ESCAPE '\';
3. NULL 值处理
-- 模糊查询不匹配 NULL 值!
SELECT * FROM users 
WHERE name LIKE '%张%';  -- 自动过滤 name IS NULL 的行

四、性能优化策略

1. 避免全模糊(%xxx%
-- ❌ 性能杀手(无法利用索引)
WHERE content LIKE '%数据库%'  -- ✅ 优化方案1:右模糊(可命中索引)
WHERE content LIKE '数据库%'  -- ✅ 优化方案2:全文索引(MySQL 5.6+)
ALTER TABLE articles ADD FULLTEXT INDEX (content);
SELECT * FROM articles 
WHERE MATCH(content) AGAINST('数据库' IN BOOLEAN MODE);
2. 慎用函数包裹列
-- ❌ 索引失效
WHERE LOWER(name) LIKE '%abc%'  -- ✅ 预处理数据
ALTER TABLE users ADD COLUMN name_lower VARCHAR(50);
UPDATE users SET name_lower = LOWER(name);  
CREATE INDEX idx_name_lower ON users(name_lower);
WHERE name_lower LIKE '%abc%';  -- 仍全扫,但比函数快
3. 使用覆盖索引
-- 只需返回 name 和 id
SELECT name, id FROM users 
WHERE name LIKE '张%';  -- 若索引含(name,id)则无需回表

🔧 五、进阶技巧

1. 正则表达式增强(REGEXP)
-- MySQL/PgSQL 支持
WHERE name REGEXP '^张[小大]'  -- 匹配"张小"或"张大"开头-- Oracle 用 REGEXP_LIKE
WHERE REGEXP_LIKE(name, '^张[小大]')
2. 通配符组合妙用
-- 匹配 130-139 开头的手机号
WHERE phone LIKE '13_%'        -- 简易版(可能包含无效号)
WHERE phone REGEXP '^13[0-9]{9}$'  -- 精确版(11位数字)-- 匹配邮箱格式
WHERE email LIKE '%@%.%'       -- 基础验证
3. 动态模式生成
-- 根据变量构造模式
SET @search_term = '数据';
SELECT * FROM books 
WHERE title LIKE CONCAT('%', @search_term, '%');

🧩 六、实战陷阱案例

陷阱1:中文字符截断错误
-- UTF-8 下 '李_' 可能匹配到 "李三"(3字节)或 "李𠮷"(4字节)
✅ 解决方案:使用 `CHAR_LENGTH()` 辅助
WHERE name LIKE '李_' AND CHAR_LENGTH(name) = 2
陷阱2:通配符冲突
-- 用户输入含 "%" 时(如搜索 "100%")
✅ 方案:预处理输入值
SET @input = REPLACE(@raw_input, '%', '\%');
WHERE content LIKE CONCAT('%', @input, '%') ESCAPE '\';
陷阱3:隐式空格问题
-- VARCHAR 存储时尾部空格参与匹配
CREATE TABLE test (col VARCHAR(10));
INSERT INTO test VALUES ('abc'), ('abc   ');SELECT * FROM test WHERE col LIKE 'abc';   -- 只匹配 'abc'
SELECT * FROM test WHERE col LIKE 'abc%';  -- 匹配两项

📊 七、模糊查询类型性能对比

查询类型示例索引利用适用场景
前缀匹配LIKE '张%'✅ 可利用B树索引快速人名/编号检索
后缀匹配LIKE '%公司'❌ 全表扫描低频分析
全模糊LIKE '%数据%'❌ 全表扫描小表或全文索引替代方案
固定位置LIKE '__小%'❌ 全表扫描严格格式数据(如身份证)

💡 终极建议

  1. 数据清洗:入库前规范化(统一大小写/去除特殊字符)
  2. 索引策略:对高频前缀查询列建索引
  3. 替代方案
    模糊查询
    数据量
    LIKE
    全文搜索引擎
    Elasticsearch
    PgSQL全文索引
  4. 安全防护:过滤用户输入的通配符(防止恶意超长%拖垮数据库)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/85082.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/85082.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[论文阅读] (39)EuroSP25 CTINEXUS:基于大模型的威胁情报知识图谱自动构建

《娜璋带你读论文》系列主要是督促自己阅读优秀论文及听取学术讲座,并分享给大家,希望您喜欢。由于作者的英文水平和学术能力不高,需要不断提升,所以还请大家批评指正,非常欢迎大家给我留言评论,学术路上期…

强化学习三大分类

核心目标: 教会一个智能体(比如机器人、游戏AI、推荐系统)通过试错和奖励,学会在某个环境中完成特定任务的最佳策略。 核心角色: 智能体 (Agent): 学习者,比如玩游戏的小人、控制温度的空调系…

城市排水生命线安全运行监测项目

近年来,城市内涝、污水溢流等问题频发,让排水管网这一"城市生命线"的安全运行备受关注。如何让地下的"毛细血管"更智能、更可靠?本文将带您深入解析城市排水生命线安全运行监测项目的建设逻辑与技术内核,看科…

LeetCode - 34. 在排序数组中查找元素的第一个和最后一个位置

题目 34. 在排序数组中查找元素的第一个和最后一个位置 - 力扣&#xff08;LeetCode&#xff09; 思路 查找左边界 初始化 left 0, right nums.size() - 1 当 left < right 时循环&#xff1a; 计算中点 mid left (right - left) / 2 如果 nums[mid] < target…

Tesollo四指灵巧手DG-4F:18自由度与多种抓取模式结合实现高精度操作

Tesollo四指灵巧手 DG-4F 是一款具备 18 自由度的多模态末端执行器&#xff0c;采用模块化结构设计&#xff0c;融合人手灵活性与夹爪高效性特点。该产品兼容 Universal Robots、Techman、Doosan Robotics、Rainbow Robotics 等主流机器人平台&#xff0c;适用于工业自动化、科…

深入浅出JavaScript 原型链:对象继承的“隐形链条”

深入浅出JavaScript 原型链&#xff1a;对象继承的“隐形链条” 在 JavaScript 的世界里&#xff0c;原型链&#xff08;Prototype Chain&#xff09;是一个核心概念。它如同一条隐形的链条&#xff0c;连接着所有对象&#xff0c;使得代码能够高效地共享属性和方法。理解原型…

LINUX中MYSQL的使用

LINUX中MYSQL的使用 MYSQL的数据类型 bool&#xff1a; 布尔类型 0 或者 1 CHAR&#xff1a; 单字符的字符 CHAR&#xff08;n&#xff09;:多字节字符 VARCHAR&#xff08;n&#xff09;&#xff1a;可变长度的字符型 TINYINT &#xff1a; 单字节整型 SMALLINT&#x…

打卡第48天:随机函数与广播机制

知识点回顾&#xff1a; 随机张量的生成&#xff1a;torch.randn函数卷积和池化的计算公式&#xff08;可以不掌握&#xff0c;会自动计算的&#xff09;pytorch的广播机制&#xff1a;加法和乘法的广播机制 ps&#xff1a;numpy运算也有类似的广播机制&#xff0c;基本一致 …

学习昇腾开发的第四天--基本指令

1、查看npu当前状态信息 npu-smi info 2、查看NPU的ID npu-smi info -l3、调用python python3 4、修改用户名 su - HwHiAiUser 5、查看cann版本 cat /usr/local/Ascend/ascend-toolkit/latest/compiler/version.info 6、删除文件夹 sudo rm -rf HelloWorld7、在本地环…

vue3 - 自定义hook

自定义hook 简单点来说就是将人物或者订单的所有数据和方法放在一个ts文件里面 这样便于维护 假如一个人只需要管 人物的模块 那他只需要操作usePerson.ts文件就可以了 //useDog.ts import { ref,reactive} from vue; import axios from axios;export default function(){…

【python】bash: !‘: event not found

报错 # 2. 测试smplx是否工作&#xff08;可能不需要chumpy&#xff09; python -c "import smplx; print(✅ smplx works!)"bash: !: event not found 分析 这是bash的历史扩展问题&#xff0c;感叹号被解释为历史命令。用这些方法解决&#xff1a; &#x1f680…

【Python打卡Day47】注意力热力图可视化@浙大疏锦行

可视化空间注意力热力图的意义&#xff1a; 提升模型可解释性 热力图能直观展示模型决策的依据区域&#xff0c;破除深度学习"黑箱"困境。例如在图像识别中&#xff0c;可以看到模型识别"猫"是因为关注了猫耳和胡须区域&#xff0c;识别"禁止通行&qu…

树状数组 2

L - 树状数组 2 洛谷 - P3368 Description 如题&#xff0c;已知一个数列&#xff0c;你需要进行下面两种操作&#xff1a; 将某区间每一个数加上 x&#xff1b; 求出某一个数的值。 Input 第一行包含两个整数 N、M&#xff0c;分别表示该数列数字的个数和操作的总个数。…

YOLOv2 技术详解:目标检测的又一次飞跃

&#x1f9e0; YOLOv2 技术详解&#xff1a;目标检测的又一次飞跃 一、前言 在 YOLOv1 提出后&#xff0c;虽然实现了“实时性 单阶段”的突破&#xff0c;但其在精度和小物体检测方面仍有明显不足。为了弥补这些缺陷&#xff0c;Joseph Redmon 等人在 2017 年提出了 YOLOv2…

JAFAR Jack up Any Feature at Any Resolution

GitHub PaPer JAFAR: Jack up Any Feature at Any Resolution 摘要 基础视觉编码器已成为各种密集视觉任务的核心组件。然而&#xff0c;它们的低分辨率空间特征输出需要特征上采样以产生下游任务所需的高分辨率模式。在这项工作中&#xff0c;我们介绍了 JAFAR——一种轻量级…

SamWaf 开源轻量级网站防火墙源码(源码下载)

SamWaf网站防火墙是一款适用于小公司、工作室和个人网站的开源轻量级网站防火墙&#xff0c;完全私有化部署&#xff0c;数据加密且仅保存本地&#xff0c;一键启动&#xff0c;支持Linux&#xff0c;Windows 64位,Arm64。 主要功能&#xff1a; 代码完全开源 支持私有化部署…

79Qt窗口_QDockWidget的基本使用

目录 4.1 浮动窗⼝的创建 4.2 设置停靠的位置 浮动窗⼝ 在 Qt 中&#xff0c;浮动窗⼝也称之为铆接部件。浮动窗⼝是通过 QDockWidget类 来实现浮动的功能。浮动窗 ⼝⼀般是位于核⼼部件的周围&#xff0c;可以有多个。 4.1 浮动窗⼝的创建 浮动窗⼝的创建是通过 QDockWidget…

UE/Unity/Webgl云渲染推流网址,如何与外部网页嵌套和交互?

需求分析&#xff1a;用threejs开发的数字孪生模型&#xff0c; 但是通过webgl技术网页中使用&#xff0c;因为模型数据量大&#xff0c;加载比较慢&#xff0c;且需要和其他的业务系统进行网页嵌套和交互&#xff0c;使用云渲染技术形成的推流网址&#xff0c;如何与外部网页嵌…

在Termux中搭建完整Python环境(Ubuntu+Miniconda)

蹲坑也能写python? 📱 环境准备🛠 详细搭建步骤步骤1:安装Linux容器工具步骤2:查看可用Linux发行版步骤3:安装Ubuntu系统步骤4:登录Ubuntu环境步骤5:下载Miniconda安装包步骤6:安装Miniconda⚡ 环境验证💡 使用技巧⚠️ 注意事项前言:想在吃饭、通勤甚至休息间隙…

EventSourcing.NetCore:基于事件溯源模式的 .NET Core 库

在现代软件架构中&#xff0c;事件溯源&#xff08;Event Sourcing&#xff09;已经成为一种非常流行的模式&#xff0c;尤其适用于需要高可用性和数据一致性的场景。EventSourcing.NetCore 是一个基于事件溯源模式的 .NET Core 库&#xff0c;旨在帮助开发者更加高效地实现这一…