SQL LIKE 语句中下划线“_”是通配符

1. 问题描述

sql语句的where条件中,使用 type like 'object_%' ,期望筛选出以"object_" 开头的数据,如 object_test, object_data 等。

但返回结果里包含了 "objectAnything"这种不含下划线"_"的数据。

2. 问题分析

这个问题很典型,是由于 _(下划线)在 SQL LIKE 语句中是通配符 导致的。

在 SQL 的 LIKE 语句中:

  • % 匹配任意数量的字符(包括零个字符)
  • _ 匹配单个任意字符

所以当写 type LIKE 'object_%' 时,实际匹配的是:

  • 以 "object" 开头
  • 后面跟任意一个字符
  • 然后再跟任意数量的字符

因此 objectAnything 被匹配到是因为:

  • object ✅ 匹配前六个字符
  • A ✅ 匹配 _(任意单个字符)
  • nything ✅ 匹配 %(剩余所有字符)

3. 解决方案

如果想匹配字面意义上的下划线 _,需要使用 转义字符.

方法1:使用 ESCAPE 子句(推荐)

sql 复制代码
-- 使用反斜杠作为转义字符
SELECT * FROM your_table WHERE type LIKE 'object\_%' ESCAPE '\';

-- 或者使用其他转义字符,比如 !
SELECT * FROM your_table WHERE type LIKE 'object!_%' ESCAPE '!';

方法2:使用方括号(SQL Server 特有)

sql 复制代码
-- SQL Server 中可以将通配符放在方括号中
SELECT * FROM your_table WHERE type LIKE 'object[_]%';

方法3:使用等号精确匹配前缀(如果适用)

sql 复制代码
SELECT * FROM your_table WHERE LEFT(type, 7) = 'object_';
相关推荐
先吃饱再说13 小时前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils13 小时前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend16 小时前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶16 小时前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung17 小时前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql
parade岁月17 小时前
MySQL JOIN解析:朴实无华但食之有味
数据库·后端
用户31693538118318 小时前
MySQL服务无法启动问题解决全记录
数据库
vivo互联网技术21 小时前
从 10 分钟到 1 秒:ES 深度分页任意跳页的三轮优化实战
服务器·数据库·redis·elasticsearch·深度分页
倔强的石头_2 天前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB2 天前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python