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_';
相关推荐
fen_fen1 小时前
Oracle建表语句示例
数据库·oracle
砚边数影3 小时前
数据可视化入门:Matplotlib 基础语法与折线图绘制
数据库·信息可视化·matplotlib·数据可视化·kingbase·数据库平替用金仓·金仓数据库
orange_tt3 小时前
Djiango配置Celery
数据库·sqlite
云小逸4 小时前
【nmap源码学习】 Nmap网络扫描工具深度解析:从基础参数到核心扫描逻辑
网络·数据库·学习
肉包_5114 小时前
两个数据库互锁,用全局变量互锁会偶发软件卡死
开发语言·数据库·c++
霖霖总总4 小时前
[小技巧64]深入解析 MySQL InnoDB 的 Checkpoint 机制:原理、类型与调优
数据库·mysql
此刻你5 小时前
常用的 SQL 语句
数据库·sql·oracle
それども5 小时前
分库分表的事务问题 - 怎么实现事务
java·数据库·mysql
·云扬·6 小时前
MySQL Binlog 配置指南与核心作用解析
数据库·mysql·adb
天空属于哈夫克36 小时前
Java 版:利用外部群 API 实现自动“技术开课”倒计时提醒
数据库·python·mysql