繁体   English   中英

使用 LIKE 在 SQL 中搜索

[英]Using LIKE to search in SQL

我有一个 SQL 查询如下。

select *
from table 
where content like '%' + search_content + '%' 

如果search_content = 'JAVA' ,它将返回包含xxxJAVAxxx的数据,这是可以的。

但是如果我的search_content = 'JAVA ABC XYZ' ,它不会返回包含xxxJAVAxxx的数据。 这不是我想要的情况。

我该如何处理这种情况?

考虑到您的示例,您可以添加OR条件以涵盖所有情况:内容包含所需的字符串、开始或结束。

select *
from table 
where (content like '%JAVA%' or content like 'JAVA%' or content like '%JAVA')

一种更优雅的方式(假设您使用 postgres)

select *
from table
where position('JAVA' in content) > 0

它能做什么? 它找到 position,其中可以在内容中找到“JAVA”substring。 如果 substring 存在,则位置高于 0。

您可以在 SQL 服务器中找到等效功能。

select *
from table
where CHARINDEX('JAVA', content) > 0

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM