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_';
相关推荐
霸王大陆1 小时前
《零基础学PHP:从入门到实战》教程-模块七:MySQL 数据库基础-3
数据库·mysql·php
老华带你飞1 小时前
茶叶商城|基于SprinBoot+vue的茶叶商城系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot
我科绝伦(Huanhuan Zhou)1 小时前
Oracle性能优化方法论:从基线建立到问题根治
数据库·oracle·性能优化
秋邱1 小时前
AR + 离线 AI 实战:YOLOv9+TensorFlow Lite 实现移动端垃圾分类识别
开发语言·前端·数据库·人工智能·python·html
X***07881 小时前
使用bitnamiredis-sentinel部署Redis 哨兵模式
数据库·redis·sentinel
zwm_yy1 小时前
mysql安全优化
数据库·mysql·adb
爱可生开源社区2 小时前
SQLShift V5.0 发布!引入增强模型:复杂 SQL 转换准确率质变
数据库·sql
CC.GG2 小时前
【C++】面向对象三大特性之一——继承
java·数据库·c++