SQL LIKE 相似信息查找语句

LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。

LIKE 操作符是 SQL 中用于在 WHERE 子句中进行模糊查询的关键字(就是找跟输入信息相似的),它允许我们根据模式匹配(就是与这个数据相似的数据)来选择数据,通常与 %_ 通配符一起使用。

就是:

LIKE 就是"像什么"的意思------用来在数据库里"模糊查找"你想要的数据,不用知道完整内容也能找到!

SELECT column1, column2, ...

FROM table_name

WHERE column_name LIKE pattern;

参数说明:

  • column1, column2, ...:要选择的字段名称,可以为多个字段。如果不指定字段名称,则会选择所有字段。
  • table_name:要查询的表名称。
  • column:要搜索的字段名称。
  • pattern:要搜索的相似的字段信息

使用 % 通配符找出所有以 "iPhone" 开头的产品:

SELECT ProductName, Category

FROM Products

WHERE ProductName LIKE 'iPhone%';

解释:名字开头是 iPhone,后面随便是什么都行。

✅ 匹配:

iPhone 15、iPhone SE、iPhone

❌ 不匹配:

My iPhone(因为不是开头)

使用 _ 通配符找出所有产品名称第二个字符为 "e" 的产品:

SELECT ProductName, Category

FROM Products

WHERE ProductName LIKE '_e%';

解释:第一个字符随便,第二个必须是 e,后面随便。

✅ 匹配:BeatsRedmiLePhone

❌ 不匹配:Apple(第二个是 p)、eBook(第一个就是 e)

结合 % 和 _ 通配符找出所有产品名称包含 "Zoom" 的产品:

SELECT ProductName, Category

FROM Products

WHERE ProductName LIKE '%Zoom%';

👉 解释:名字里只要有 Zoom 这几个字就行,不管前后是什么。

✅ 匹配:

Zoom Lens、SuperZoom Pro、MiniZoom

SQL LIKE 操作符实例

下面的 SQL 语句选取 name 以字母 "G" 开始的所有客户:

SELECT * FROM Websites

WHERE name LIKE 'G%';

提示:"%" 符号用于在模式的前后定义通配符(默认字母)。您将在下一章中学习更多有关通配符的知识。

下面的 SQL 语句选取 name 以字母 "k" 结尾的所有客户:

SELECT * FROM Websites

WHERE name LIKE '%k';

SQL 语句选取 name 包含模式 "oo" 的所有客户:

SELECT * FROM Websites

WHERE name LIKE '%oo%';

通过使用 NOT 关键字,您可以选取不匹配模式的记录。

下面的 SQL 语句选取 name 不包含模式 "oo" 的所有客户:

SELECT * FROM Websites

WHERE name NOT LIKE '%oo%';

👉 解释:只要名字里没有连续的 oo 就选出来。

✅ 匹配:Google ❌(有 oo,所以被排除)

✅ 匹配:BingYahoo(Yahoo 有 oo 吗?有!所以也被排除)

✅ 真正被选中的是:AppleTesla 这种不含 "oo" 的。

要注意的点:

• 大小写问题:有些数据库(如 MySQL)默认不区分大小写,LIKE '%GOOGLE%' 也能找到

google;但有些(如 PostgreSQL)会区分,需要写成 LOWER(name) LIKE '%google%' 更保险。

• 性能注意:如果写成 LIKE '%xxx'(开头是 %),数据库没法用索引,数据量大时会变慢。

• 转义特殊字符:如果你真要查名字里带 % 的(比如"折扣90%"),需要用转义:

相关推荐
廋到被风吹走8 小时前
【数据库】【MySQL】InnoDB外键解析:约束机制、性能影响与最佳实践
android·数据库·mysql
掘根8 小时前
【消息队列】交换机数据管理实现
网络·数据库
Logic1018 小时前
《Mysql数据库应用》 第2版 郭文明 实验6 数据库系统维护核心操作与思路解析
数据库·sql·mysql·学习笔记·计算机网络技术·形考作业·国家开放大学
AI Echoes9 小时前
构建一个LangChain RAG应用
数据库·python·langchain·prompt·agent
@nengdoudou9 小时前
KingbaseES支持 mysql 的find_in_set函数
数据库·mysql
摇滚侠10 小时前
面试实战 问题三十三 Spring 事务常用注解
数据库·spring·面试
梁萌10 小时前
保姆级的MySQL执行计划(Explain)解读
数据库·mysql·explain·执行计划
JIngJaneIL10 小时前
基于Java+ vue智慧医药系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
+VX:Fegn089510 小时前
计算机毕业设计|基于springboot + vue图书管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
杨云龙UP11 小时前
MySQL 8.0.x InnoDB 写入链路优化:Redo Log 与 Buffer Pool 扩容与缓冲区调优实战记录-20251029
linux·运维·数据库·sql·mysql